簡體   English   中英

在Android中,為什么不更新SQLite數據庫?

[英]In Android, why won't the SQLite Database update?

我正在嘗試使用以下方法更新行:

myDatabase.update(DATABASE_TABLE, cvUpdate, KEY_NAME + "=" + mName, null);

但我收到以下錯誤:

錯誤/數據庫(282):使用UPDATE peopleTable SET person_name =?更新person_name = Bob時出錯。 WHERE person_name =鮑勃

我正在使用以下代碼嘗試更新:

public void updateEntry(String mName) throws SQLException {

    ContentValues cvUpdate = new ContentValues();
    cvUpdate.put(KEY_NAME, mName);
    ourDatabase.update(DATABASE_TABLE, cvUpdate, KEY_NAME + "=" + mName, null);

}

我看過其他似乎與這個問題相似的答案,但是我沒有找到確定的解決方案。 這似乎與變量有關,但我可能完全錯了。

您沒有將字符串用引號引起來。 您最好這樣做:

ourDatabase.update(DATEABASE_TABLE, cvUpdate, KEY_NAME + "= ?", new String[]{mName});

當您使用上述代碼時,如果類型為字符串,它將自動將參數括在單引號中。

“ persons_name = Bob”可能應該是“ persons_name ='Bob'”,因此請嘗試:

ourDatabase.update(DATABASE_TABLE, cvUpdate, KEY_NAME + "='" + mName + "'", null);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM