android-使用insertWithOnConflict进行更新或插入

我需要插入或更新,并且找到了sqliteDatabase方法insertWithOnConflict,但是我不知道它如何检查条目是否已经存在.

从理论上讲,我需要一个“ Where”参数来检查某个ID是否存在,如果存在,它应该替换所有其他列.

这就是我现在所拥有的,但是我不认为第二个参数是唯一ID

    ContentValues args = new ContentValues();
    args.put(AppDatabase.COLUMN_ID, entry.getId());
    args.put(AppDatabase.COLUMN_NAME, entry.getAppname());
    args.put(AppDatabase.COLUMN_URL, entry.getAppUrl());
    database.insertWithOnConflict(AppDatabase.TABLE_FILELIST, COLUMN_ID, args, sqliteDatabase.CONFLICT_REPLACE);

我该如何管理这种行为?

解决方法:

>确保您的表中有一些适当的约束,例如PRIMARY KEY或UNIQUE.
>插入时,通过ContentValues将值添加到此约束列中.如果插入新行会违反某些约束,则首先删除冲突的行,然后再插入新行.

在您的情况下,COLUMN_ID看起来很适合作为PRIMARY KEY约束的候选对象.您的代码中的第二个arg nullColumnHack值为COLUMN_ID是不必要的,您可以将其作为null传递.

相关文章

SQLite架构简单,又有Json计算能力,有时会承担Json文件/RES...
使用Python操作内置数据库SQLite以及MySQL数据库。
破解微信数据库密码,用python导出微信聊天记录
(Unity)SQLite 是一个软件库,实现了自给自足的、无服务器...
安卓开发,利用SQLite实现登陆注册功能