ContentValues 和HashTable類似都是一種存儲的機制 但是兩者最大的差別就在于,contenvalues隻能存儲基本類型的資料,像string,int之類的,不能存儲對象這種東西,而HashTable卻可以存儲對象。
在向資料庫中插入資料的時候,首先應該有一個ContentValues的對象,是以:
ContentValues initialValues = new ContentValues();
initialValues.put(key,values);
SQLiteDataBase sdb ;
sdb.insert(database_name,null,initialValues);
插入成功就傳回記錄的id否則傳回-1;
就可以插入一行資料,詳細見下面代碼
public Uri insert(Uri uri, ContentValues initialValues) {
if (uriMatcher.match(uri) != CONTACTS) {
throw new IllegalArgumentException("unknow uri " + uri);
}
ContentValues values;
if (initialValues != null) {
values = new ContentValues(initialValues);
System.out.println("contentValues插入成功,initailValues不是空的");
} else {
values = new ContentValues();
}
Long now = Long.valueOf(System.currentTimeMillis());
// 設定預設值
if (values.containsKey(ContactColumn.CREATED) == false) {
values.put(ContactColumn.CREATED, now);
}
if (values.containsKey(ContactColumn.NAME) == false) {
values.put(ContactColumn.NAME, now);
}
if (values.containsKey(ContactColumn.EMAIL) == false) {
values.put(ContactColumn.EMAIL, now);
}
if (values.containsKey(ContactColumn.MOBILE) == false) {
values.put(ContactColumn.MOBILE, now);
}
if (values.containsKey(ContactColumn.MODIFIED) == false) {
values.put(ContactColumn.MODIFIED, now);
}
System.out.println("應該插入成功了吧");
long RowId = contactsDB.insert(CONTACTS_TABLE, null, values);
if (RowId > 0) {
Uri noteUri = ContentUris.withAppendedId(CONTENT_URI, RowId);
getContext().getContentResolver().notifyChange(noteUri, null);
System.out.println("到這裡也是沒問題的!");
return noteUri;
}
throw new IllegalArgumentException("unknow uri " + uri);
}
當然以上代碼是根據Uri來操作的是以要想明白代碼怎麼回事?還要明白ContentProvider到底是怎麼存儲資料的!