ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
来源:互联网 发布:益思商科留学 知乎 编辑:程序博客网 时间:2024/05/16 05:26
http://blog.csdn.net/androidzhaoxiaogang/article/details/8180628
1.SQLiteOpenHelper是将对数据库和表的创建、插入、更新、删除操作进行了简单的封装;
2.而ContentProvider可以说是一个对外的接口,除了可以实现对SQLiteOpenHelper的封装,还可以实现对文件操作、图片操作、对象操作等实现封装;
3.在多线程中使用SQLiteOpenHelper要考虑线程同步问题,而如果使用ContentProvider的话基本不用考虑;
4.另外在对事务的支持时SQLiteDatabase和ContentProvider的写法有所不同:
- mDatabase.beginTransaction();
- try{
- //在这里执行多个数据库操作
- //执行过程中可能会抛出异常
- mDatabase.setTransactionSuccessful();
- //在setTransactionSuccessful和endTransaction之间不进行任何数据库操作
- }catch(Exception e){
- //当数据库操作出现错误时,需要捕获异常,结束事务
- mDatabase.endTransaction();
- throw e;
- }
- //当所有操作执行完成后结束一个事务
- mDatabase.endTransaction();
- }
而后者是通过重写ContentProvider的applyBatch或者bulkInsert方法来实现:
- @Override
- public int bulkInsert(Uri uri, ContentValues[] values) {
- int numValues = values.length;
- mDb = mOpenHelper.getWritableDatabase();
- mDb.beginTransaction();
- try {
- for (int i = 0; i < numValues; i++) {
- Uri result = insertInTransaction(uri, values[i]);
- }
- mDb.setTransactionSuccessful();
- } finally {
- mDb.endTransaction();
- }
- return numValues;
- }
- @Override
- public ContentProviderResult[] applyBatch(ArrayList<ContentProviderOperation> operations)
- throws OperationApplicationException {
- mDb = mOpenHelper.getWritableDatabase();
- mDb.beginTransaction();
- try {
- final int numOperations = operations.size();
- final ContentProviderResult[] results = new ContentProviderResult[numOperations];
- for (int i = 0; i < numOperations; i++) {
- final ContentProviderOperation operation = operations.get(i);
- results[i] = operation.apply(this, results, i);
- }
- mDb.setTransactionSuccessful();
- return results;
- } finally {
- mDb.endTransaction();
- }
- }
(注意上面的代码在放到项目中时可能还需要额外补充,这里只是代码片段思路)
5.另外在使用AsynQueryHandler的时候,使用ContentProvider也更为方便;
6.使用ContentProvider的代码比其它方式都简洁明了;
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- SQLiteDataBase、SQLiteOpenHelper、ContentProvider介绍和区别
- android4————SQLiteOpenHelper SQLiteDatabase ContentProvider三者的关系
- SQLiteDatabase和SQLiteOpenHelper的不同
- application,session,cookie三者之间的区别和联系
- SQLiteDatabase 和 SQLiteOpenHelper
- Context与SQLiteDatabase的方法openOrCreateDatabase的区别 (context、SQLiteOpenHelper)
- Context与SQLiteDatabase的方法openOrCreateDatabase的区别 (context、SQLiteOpenHelper)
- 计算机视觉,计算机图形学和数字图像处理,三者之间的联系和区别
- 【转】计算机视觉,计算机图形学和数字图像处理,三者之间的联系和区别
- android SQLiteOpenHelper和ContentProvider的结合使用
- 从“分析”的角度谈OLAP、数据挖掘、统计分析三者之间的区别和联系
- Android中Uri和ContentProvider以及ContentResolver之间的联系
- 等级保护、风险评估和安全测评三者之间的区别与联系
- Linux下/proc目录简介
- Objective-C-类(static)方法、实例方法、overwrite(覆写)、属性(property)
- CSRF原理、测试方法
- java system.out.printf()的常见使用方法
- python 产生随机数,随机字符串
- ContentProvider,SQLiteOpenHelper,SQLiteDatabase三者之间的区别和联系
- 提取汉字首字母C#代码
- datatable中Global与Action的迭代
- jQuery性能优化的28个建议
- error LNK2019:无法解析的外部符号 __cdecl std::_String_base::_Xran(void) 和_Xlen(void)
- Jenkins hash
- baidu美化之网页标题问题最新美化规定
- linux 复制多行
- java 中this关键词的使用