为什么我不能更新sqlite数据库的值

时间:2015-10-16 17:26:43

标签: java sqlite sql-update add

  public void onClick(View v) {

            if (btn66 == v) {
                ContentValues value = new ContentValues();
                value.put(DBhelper.Amount, txtBudget.getText().toString());
                value.put(DBhelper.Description, txr.getText().toString());

                if(DBhelper.Amount == null)
                {
                    db = helper.getWritableDatabase();
                    db.insert(DBhelper.TABLE2, null, value);
                    db.close();
                    clearfield();
                    Toast.makeText(this, "Budget add Successfully", Toast.LENGTH_LONG).show();
                    fetchData2();
                    Intent i = new Intent(addbudget.this, MainActivity.class);
                    startActivity(i);

                }
                else{
                    db = helper.getWritableDatabase();
                    db.update(DBhelper.TABLE2, value, "_id "+"="+1, null);
                    db.close();

                    fetchData2();
                    Toast.makeText(this, "Update Successfully", Toast.LENGTH_LONG).show();
                    clearfield();
                }
            }
        }

上面的代码是我在sqlite数据库中添加和更新值的代码,在我的代码中包含Update方法之后,我的add函数无效,我的更新功能也无法正常工作。我的代码有任何问题,但我没有收到任何错误信息。

这是我的数据库表

     static final String C_ID = "_id";
        static final String Name = "name";
        static final String B_ID = "_id";

        public void onCreate(SQLiteDatabase db){

                db.execSQL("CREATE TABLE " + TABLE1+ "(" +C_ID
                        + " INTEGER PRIMARY KEY AUTOINCREMENT," +Name+ " text unique not null)");

                db.execSQL("CREATE TABLE " + TABLE2+ "(" +B_ID
                        + " INTEGER PRIMARY KEY AUTOINCREMENT," +Description+ " text,"
                        +Amount+ " text, FOREIGN KEY ("+Description+") REFERENCES "+TABLE1+"("+Name+"));");




   }

1 个答案:

答案 0 :(得分:1)

尝试使用类似的内容检查name中是否存在具有给定table1的行:

public boolean checkIfRowPresent(String name) {
    SQLiteDatabase db = helper.getWritableDatabase();

    Cursor cursor =
            db.query(DBhelper.TABLE1, null, DBHelper.NAME + "='" + name + "'", null, null, null,
                    null, null);
    boolean ret = false;
    if (cursor.getCount() > 0) {
        ret = true; // There is a row present in table1 with the given name
    }
    db.close();

    return ret;

}

你应该用它来称呼它:

checkIfRowPresent(txr.getText().toString())

让我知道它是否有帮助?