我有一个自定义
Android ContentProvider,它存储和检索sqlite数据库中的数据.
我们假设其中一个数据库表有一个_ID列和一个NAME列以及如下内容:
|==========|==========| | _ID | NAME | |==========|==========| | 1 | d1 | | 2 | d2 | | 3 | d3 | | 4 | d4 | |==========|==========|
此sqlite DB与远程数据库保持同步,并通过网络定期获取新数据.
表中可能的操作如下:
现在假设所有可能的操作立即发生,并且在从远程服务器获取一些最新数据之后,该表的新内容必须设置如下:
|==========|==========| | _ID | NAME | |==========|==========| | 1 | d7 | | 3 | d3 | | 4 | d6 | | 5 | d5 | |==========|==========|
可以有两种不同的方法:
>查询数据库并检查每个现有行以查看是否需要更新,然后添加任何新行并删除任何缺失的行 – 尽管如果我们想要使用分页方法更新数据库,这种方法可能有点棘手没有一个网络提取
>使用单个DELETE sql命令删除整个表,然后添加从服务器接收的所有行
在Android上,我目前正在使用批处理操作实现第二种方法,以最大限度地提高性能:
final ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperation>(); // with this URI,the content provider deletes all rows operations.add(ContentProviderOperation.newDelete(Users.CONTENT_URI).build()); final ContentValues values = new ContentValues(); values.put(ID_COLUMN,1); values.put(NAME_COLUMN,"d7"); values.put(ID_COLUMN,3); values.put(NAME_COLUMN,"d3"); values.put(ID_COLUMN,4); values.put(NAME_COLUMN,"d6"); values.put(ID_COLUMN,5); values.put(NAME_COLUMN,"d5"); operations.add(ContentProviderOperation.newInsert(Users.CONTENT_URI).withValues(values).build()); getApplicationContext().getContentResolver().applyBatch(MyContentProvider.AUTHORITY,operations);
编辑:例如,采用方法2,重写的ContentProvider#bulkInsert使用数据库事务可以大大加快批量插入操作:见this question.