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的写法有所不同:

[java] view plaincopy
  1. mDatabase.beginTransaction();  
  2. try{  
  3.   //在这里执行多个数据库操作  
  4.   //执行过程中可能会抛出异常  
  5.   mDatabase.setTransactionSuccessful();  
  6.   //在setTransactionSuccessful和endTransaction之间不进行任何数据库操作  
  7.   }catch(Exception e){  
  8.     //当数据库操作出现错误时,需要捕获异常,结束事务  
  9.     mDatabase.endTransaction();  
  10.     throw e;  
  11.   }  
  12.   //当所有操作执行完成后结束一个事务  
  13.   mDatabase.endTransaction();  
  14. }  

而后者是通过重写ContentProvider的applyBatch或者bulkInsert方法来实现:

[java] view plaincopy
  1. @Override  
  2.     public int bulkInsert(Uri uri, ContentValues[] values) {  
  3.         int numValues = values.length;  
  4.         mDb = mOpenHelper.getWritableDatabase();  
  5.         mDb.beginTransaction();  
  6.         try {  
  7.             for (int i = 0; i < numValues; i++) {  
  8.                 Uri result = insertInTransaction(uri, values[i]);  
  9.             }  
  10.             mDb.setTransactionSuccessful();  
  11.         } finally {  
  12.             mDb.endTransaction();  
  13.         }  
  14.   
  15.         return numValues;  
  16.     }  

[java] view plaincopy
  1. @Override  
  2.     public ContentProviderResult[] applyBatch(ArrayList<ContentProviderOperation> operations)  
  3.             throws OperationApplicationException {  
  4.         mDb = mOpenHelper.getWritableDatabase();  
  5.         mDb.beginTransaction();  
  6.         try {  
  7.             final int numOperations = operations.size();  
  8.             final ContentProviderResult[] results = new ContentProviderResult[numOperations];  
  9.             for (int i = 0; i < numOperations; i++) {  
  10.                 final ContentProviderOperation operation = operations.get(i);  
  11.                 results[i] = operation.apply(this, results, i);  
  12.             }  
  13.             mDb.setTransactionSuccessful();  
  14.             return results;  
  15.         } finally {  
  16.             mDb.endTransaction();  
  17.          }  
  18.     }  

(注意上面的代码在放到项目中时可能还需要额外补充,这里只是代码片段思路)

5.另外在使用AsynQueryHandler的时候,使用ContentProvider也更为方便;

6.使用ContentProvider的代码比其它方式都简洁明了;

原创粉丝点击