我有一个自定义的androidContentProvider存储和检索sqlite数据库中的数据。
让我们假设其中一个DB表有一个_ID列和一个NAME列,内容如下:

|==========|==========|
|   _ID    |   NAME   |
|==========|==========|
|    1     |    d1    |
|    2     |    d2    |
|    3     |    d3    |
|    4     |    d4    |
|==========|==========|

此sqlite db与远程数据库保持同步,并通过网络定期获取新数据。
表上可能的操作如下:
可以删除现有行
可以添加新行
可以修改现有行的名称列
现在假设所有可能的操作都同时发生,并且在从远程服务器获取一些最新数据之后,必须按如下方式设置此表的新内容:
|==========|==========|
|   _ID    |   NAME   |
|==========|==========|
|    1     |    d7    |
|    3     |    d3    |
|    4     |    d6    |
|    5     |    d5    |
|==========|==========|

有两种不同的方法可以做到这一点:
查询数据库并检查每个现有行以查看是否需要更新它们,然后添加任何新行并删除任何缺少的行-尽管如果我们希望使用分页方法而不是单个网络获取来更新数据库,此方法可能有点棘手
使用单个DELETEsql命令删除整个表,然后添加从服务器接收到的所有行
在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);

这是最好的方法,还是方法1(或其他方法)在性能方面更好?
编辑:例如,采用方法2,使用数据库事务的重写ContentProvider#bulkInsert可以大大加快批插入操作:请参见。

最佳答案

最好的选项需要正确的API实现-当您应该存储一些数据库版本(int或最后一次更新的时间戳,或其他什么)时。
在更新期间,服务器用数据响应,操作类型为添加、更新、删除。

07-24 09:44
查看更多