重复插入 解决办法:
1. 因为ContentProvider 所拥有的函数接口 比如:insert delete update onCreate 都已经固定 不支持自定义 所以我打算以patch的形式
2. 函数原型
public class ResolverUtility {
/* - insertUnique
* - arguments:
* * cr : ContentResolver instance to use
* * uri : target w/ Uri format to insert
* * cv : ContentValues to insert
* * uid : unique column to replace
*
* - return:null
*/
public static void insertUnique(ContentResolver cr,
Uri uri, ContentValues cv, String uid){
String scase = (String)cv.get(uid);
String selection = "name = '"+scase+"'";
Cursor c = cr.query(uri, null, selection, null, null);
if(c.getCount() > 0){
cr.update(uri, cv, selection, null);
}
else {
cr.insert(uri, cv);
}
}
}
2. 原理:
其实 原理很简单 即:
在新插入数据之前 先查询指定列的值 并以之为条件 查询是否存在 该数据
如果存在 则调用update() 方法更新目标
如果不存在 则调用insert()方法插入之
3. 如何使用:
ContentValues uvalues = new ContentValues();
uvalues.put(CHelper.NAME, "griffinshi");
uvalues.put(CHelper.NUMBER, 7686);
uvalues.put(CHelper.HOME, "Jiangsu");
ResolverUtility.insertUnique(cResolver, CHelper.CONTENT_URI, uvalues, CHelper.NAME);
结束!
分享到:
相关推荐
ContentProvider插件化解决方案.docx
contentprovider
ContentProvider自定义以及使用系统ContentProvider
1、Android Room操作SQLite数据 2、ContentProvider使用,使用Room进行数据库操作
ContentProvider概述 ContentProvider概述 ...ContentProvider概述ContentProvider概述ContentProvider概述ContentProvider概述ContentProvider概述 ContentProvider概述ContentProvider概述ContentProvider概述
介绍ContentProvider使用方法,包括最简单的用法,一个项目中创建多个ContentProvider分别操作数据库表,以及一个ContentProvider操作多张数据库表的用法。
contentProvider 的使用以及总结
之前在用到ContentProvider时也是在网上找的教程,但是按照那些做法不怎么全面,我是没有实现出来,并且对于报错也没有给出解释原因与解决办法,也是通过借鉴与自己摸索,将自己 的一点想法分享出来。包含 ...
一看就会简单易学,contentProvider连接数据库;有注解,有注释,
ContentProvider 共享SharedPreferences 值
android contentprovider使用示例
contentProvider监听的例子
androdi ContentProvider和Uri详解
ContentProvider项目
ContentProvider封装SharedPreferences功能,解决跨进程存取值的问题, 我之前一直用自己封装的SharePreferences,后来出现跨进程问题;就用这个 ContentProvider,真好用,值得拥有!
Android ContentProvider
android 数据库 以及自定义ContentProvider demo
android contentprovider 源码 学习
关于使用ContentProvider来实现数据共享的demo
android 自定义 ContentProvider 以及 ContentResolver