android 远程同步,在Android上同步SQL数据库与REST远程服务器的最佳实践

我有一个自定义

Android ContentProvider,它存储和检索sqlite数据库中的数据.

我们假设其中一个数据库表有一个_ID列和一个NAME列以及如下内容:

|==========|==========|

| _ID | NAME |

|==========|==========|

| 1 | d1 |

| 2 | d2 |

| 3 | d3 |

| 4 | d4 |

|==========|==========|

此sqlite DB与远程数据库保持同步,并通过网络定期获取新数据.

表中可能的操作如下:

>可以删除现有行

>可以添加新行

>可以修改现有行的NAME列

现在假设所有可能的操作立即发生,并且在从远程服务器获取一些最新数据之后,该表的新内容必须设置如下:

|==========|==========|

| _ID | NAME |

|==========|==========|

| 1 | d7 |

| 3 | d3 |

| 4 | d6 |

| 5 | d5 |

|==========|==========|

可以有两种不同的方法:

>查询数据库并检查每个现有行以查看是否需要更新,然后添加任何新行并删除任何缺失的行 – 尽管如果我们想要使用分页方法更新数据库,这种方法可能有点棘手没有一个网络提取

>使用单个DELETE sql命令删除整个表,然后添加从服务器接收的所有行

在Android上,我目前正在使用批处理操作实现第二种方法,以最大限度地提高性能:

final ArrayList operations = new ArrayList();

// 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使用数据库事务可以大大加快批量插入操作:见this question.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值