Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Android sqlite插入记录(如果不存在)大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在sqlite表中添加一个新项(CheesE),但前提是它不存在.我只在表中有两列:_id(KEY_ROWID_PR)和product_name(KEY_NAME_PR).

我一直在尝试使用这些代码,但它给了我一个错误

public void populate_base_lists2(String tablename,String item) {
        ourDatabase.execsql("INSERT INTO " + tablename + " (" + KEY_NAME_PR + ") SELECT * FROM (SELECT " + item  + ") WHERE NOT EXISTS (SELECT " + KEY_NAME_PR + " FROM " + tablename + " WHERE " + KEY_NAME_PR + " = " + item + ") LIMIT 1;");
}

代码来自:MySQL: Insert record if not exists in table

没有这样的列:干酪,好吧,我把那部分更改为KEY_NAME_PR,然后错误是相同的,但没有这样的列:product_name.该栏肯定存在.

更重要的是,我需要对此代码进行一些解释.我在一定程度上有sql知识,但我无法得到这个.

谢谢

解决方法

我认为你可能需要在变量项出现时单引号,因为它的值不是列名.
试试这段代码

public void populate_base_lists2(String tablename,String item) {
ourDatabase.execsql("INSERT INTO " + tablename +
" (" + KEY_NAME_PR + ") SELECT * FROM (SELECT '" + item  + "')
WHERE NOT EXISTS (
SELECT " + KEY_NAME_PR +
" FROM " + tablename + " WHERE " + KEY_NAME_PR + " = '" + item + "'
) LIMIT 1;");
}

希望有所帮助.

大佬总结

以上是大佬教程为你收集整理的Android sqlite插入记录(如果不存在)全部内容,希望文章能够帮你解决Android sqlite插入记录(如果不存在)所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。