2012-10-30 103 views
-2

我有一個關於日期選擇器功能的問題。如何日期選擇器的值保存到SQLite數據庫

如何保存日期選擇器來SQLite數據庫的價值?

假設我創建一個按鈕來設置日期和一個按鈕來保存到數據庫...

main.java

public class main extends Activity implements OnClickListener { 

private Calendar dateTime=Calendar.getInstance(); 
     private SimpleDateFormat dateFormatter = new SimpleDateFormat("MMMM dd, yyyy"); 

@Override 
    protected void onCreate(Bundle savedInstanceState) { 
     // TODO Auto-generated method stub 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.addshoppinglist); 

     mSaveBttn = (Button) findViewById(R.id.saveBttn); 
     mSetDateBttn = (Button) findViewById(R.id.shoppingDate); 
     mCancelBttn = (Button) findViewById(R.id.cancelBttn); 
     mSaveBttn.setOnClickListener(this); 

     mSetDateBttn.setOnClickListener(this); 
     mCancelBttn.setOnClickListener(this); 
     helper = new ProductDatabaseHelper(this); 
     model = helper.getAll(); 
    } 
    public void onClick(View v) { 
     // TODO Auto-generated method stub 
     switch (v.getId()) { 
     case R.id.saveBttn: 


      break; 

     case R.id.cancelBttn: 
      Intent mainIntent = (new Intent(AddShoppingList.this, main.class)); 
      startActivity(mainIntent); 

      break; 

     case R.id.shoppingDate: 
      showDialog(DIALOG_DATE); 

     } 
    } 
protected Dialog onCreateDialog(int id){ 
     switch(id){ 
     case DIALOG_DATE: 
      return new DatePickerDialog(this,new OnDateSetListener(){ 


       public void onDateSet(DatePicker view,int year,int monthOfYear,int dayOfMonth){ 
        dateTime.set(year,monthOfYear,dayOfMonth); 

        mSetDateBttn.setText(dateFormatter 
          .format(dateTime.getTime())); 

       } 
      } ,dateTime.get(Calendar.YEAR), 
       dateTime.get(Calendar.MONTH), 
       dateTime.get(Calendar.DAY_OF_MONTH)); 



     } 

} 

有誰知道如何保存日期格式的數據庫?

回答

2

您可以通過以下方式完成此操作。

public void onDateSet(DatePicker view,int year,int monthOfYear,int dayOfMonth){ 
       dateTime.set(year,monthOfYear,dayOfMonth); 

      int year = year; // Here you can get day,month and year. 
     int month = monthOfYear; 
     int day = dayOfMonth; 

    ContentValues values = new ContentValues() 

    values.put("Day",dayOfMonth); 
    values.put("Month",monthOfYear); 
    values.put("Year",year); 

    } 

現在使用你的數據庫的輔助類使用數據庫it.For插入值讀取this post

+0

真的THX的幫助......感謝...... – jacky

+0

隨時歡迎花花公子:) – Akshay

4
DatePicker datePicker = (DatePicker) findViewById(R.id.datePicker1); 
int day = datePicker.getDayOfMonth(); 
int month = datePicker.getMonth() + 1; 
int year = datePicker.getYear(); 

保存這些不同的列日柱,月柱年柱

OR 爲了Date對象從一個datepicker使用此代碼

new Date(datePicker.getYear() - 1900, datePicker.getMonth(), datePicker.getDayOfMonth()); 

時間使用這些方法

getCurrentHour() getCurrentMinute()

1

我只是想出了一個簡單的方法,因爲我無法找到答案搜索。只是做像在實施的功能onDateSet,做自定義函數insertDate

@Override 
public void onDateSet (DatePicker view, int year, int month, int dayOfMonth) { 



    Calendar cal = new GregorianCalendar(year , month ,dayOfMonth); 
    DateFormat Dateformat = DateFormat.getDateInstance(DateFormat.MEDIUM); 
    String date = Dateformat.format(cal.getTime()); 

TextView dateText = (TextView) findViewById(R.id.dateVAl); 
    dateText.setText("JUST ADDED DATE "+ date); 

    godUri = insertDate(year, month, dayOfMonth); 
} 

private Uri insertDate( int year , int month , int dayOfMonth ) 
{ 
    ContentValues values = new ContentValues(); 
    values.put(dateContract.DateEntry.COLUMN_YEAR , year ); 
    values.put(dateContract.DateEntry.COLUMN_MONTH , month); 
    values.put(dateContract.DateEntry.COLUMN_DAY , d`enter code here`ayOfMonth); 

    //getContentResolver().insert( dateContract.DateEntry.CONTENT_URI , values); 

    dateDbHelper myDbHelper = new dateDbHelper(getApplicationContext()); 
    SQLiteDatabase database = myDbHelper.getWritableDatabase(); 
    long rowId = database.insert(dateContract.DateEntry.TABLE_NAME, null, values); 
    return ContentUris.withAppendedId(dateContract.DateEntry.CONTENT_URI , rowId); 

} 

該對象godUri(沒有雙關意)被宣佈爲全局變量。 我創建了Uri對象godUri存儲只是DatePicker.It保存日期的URI可以來得心應手一樣,發送該URI通過意圖另一個活動。

如果你想看到的我是如何創造了這個整個活動的日期選擇器的完整代碼...去這個link。 我上面提到的其他一切都是由我修改的。

相關問題