我想更新SQLite數據庫但由於某種原因更新總是失敗並返回0(行更新)。Android的SQLite數據庫WHERE語句休息更新
如果我刪除String selection = null;,那麼所有的行都更新,但我只想更新行WHERE eId =?我提供了eId。 ContentValues中的所有值都是正確的且非空。現在已經花費了我的大腦數小時..可能是一個新的眼睛會有所幫助,提前謝謝!
注意:propertyItem是可以的,所有來自我的表單的值都是正確的。當我使用選擇變量時,問題在更新時中斷。
/// COLUMN_NAME_EID == "eId"
public int updatePropertyItem (PropertyItem propertyItem) {
SQLiteDatabase db = mDbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
if (propertyItem.title != null)values.put(DatabaseContract.DataEntry.COLUMN_NAME_TITLE, propertyItem.title);
if (propertyItem.category != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_CATEGORY, propertyItem.category);
if (propertyItem.serial != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_SERIAL, propertyItem.serial);
if (propertyItem.note != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_NOTE, propertyItem.note);
if (propertyItem.purchaseDate != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_PURCHASE_DATE, propertyItem.purchaseDate);
if (propertyItem.currentValue != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_CURRENT_VALUE, propertyItem.currentValue);
if (propertyItem.replacementValue != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_REPLACE_VALUE, propertyItem.replacementValue);
if (propertyItem.store != null) values.put(DatabaseContract.DataEntry.COLUMN_NAME_STORE, propertyItem.store);
values.put(DatabaseContract.DataEntry.COLUMN_NAME_WARRANTY, propertyItem.warranty);
values.put(DatabaseContract.DataEntry.COLUMN_NAME_FAVORITE, propertyItem.favorite);
String selection = DatabaseContract.DataEntry.COLUMN_NAME_EID + " = ? ";
String[] selectionArgs = new String[] { String.valueOf(propertyItem.eId) };
int rowsUpdated = db.update(DatabaseContract.DataEntry.TABLE_NAME, values, selection, selectionArgs);
db.close();
return rowsUpdated;
}
你有沒有嘗試過使用更新爲'int rowsUpdated = db.update(DatabaseContract.DataEntry .TABLE_NAME,值,DatabaseContract.DataEntry.COLUMN_NAME_EID +「=」+ propertyItem.eId,null)'? –
您確定使用提供的eId在數據庫中存儲了一個寄存器嗎? – AlexTa
我可以知道DatabaseContract.DataEntry.COLUMN_NAME_EID列的數據類型嗎? –