【Android】ContentValues的用法
2015-11-04 23:43
411 查看
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;
就可以插入一行数据,详细见下面代码
当然以上代码是根据Uri来操作的所以要想明白代码怎么回事?还要明白ContentProvider到底是怎么存储数据的!
在忘数据库中插入数据的时候,首先应该有一个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到底是怎么存储数据的!
相关文章推荐
- 【UI基础】手势解锁简单实现
- org.hibernate.hql.ast.QuerySyntaxException: unexpected token: from near line 1, column 17 [select co
- Concurrent Request:Inactive phase,No Manager status
- Rogue游戏(三)——怪物、战斗、战争迷雾
- 深入对比分析AWT、Swing和SWT
- 深度定制一个按钮UIButton
- OS X 10.11 mysql : The server quit without updating PID file
- POJ 2778 DNA Sequence
- 深入对比分析SWT、Swing 和 AWT
- 使用uGUI制作游戏内2D动画
- MenuItem的setAsAction四种属性解析
- IOS基础UI之(十) UIPickerView和UIDatePicker详解
- easyui datagrid 单行操作中的选择行和取消行
- ArrayDeque 源码
- 用UIScrollView和UIPageControl制作相册基本方法
- leetcode-Implement Queue using Stacks
- MVC ueditor的使用(实现上传图片功能)
- Android消息机制 Handler,Looper,MessageQueue
- iOS UI 知识点
- 1017. Queueing at Bank (25)