Android sqlite插入记录(如果不存在)

时间:2012-03-11 16:40:07

标签: 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;");
}
  

03-11 17:27:20.972:E / AndroidRuntime(658):引起:   android.database.sqlite.SQLiteException:没有这样的列:奶酪:   INSERT INTO PR_Dairy_Products(product_name)SELECT * FROM(SELECT   奶酪)什么不存在(从PR_Dairy_Products中选择product_name   WHERE product_name = Cheese)LIMIT 1;

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

没有这样的专栏:干酪,好吧,我把那个部分改成了KEY_NAME_PR,然后错误是一样的,但是没有这样的专栏:product_name。该栏肯定存在。

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

由于

1 个答案:

答案 0 :(得分:3)

我认为您可能需要在变量 item 周围出现单引号,因为它的值不是列名。 试试这段代码:

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;");
}

希望有所帮助。