0

我的 Android 应用程序中有这个 SQLite 表:

CREATE TABLE " + TABLE_NAME + " (" +
        _ID + " INTEGER PRIMARY KEY AUTOINCREMENT" +
        COMMA + COLUMN_NAME_SID + " INTEGER" +
        COMMA + COLUMN_NAME_TITLE + " TEXT NOT NULL" +
        COMMA + COLUMN_NAME_IS_MINE + " BOOLEAN NOT NULL" +
        COMMA + COLUMN_NAME_CREATED_AT + " DATETIME" +
        COMMA + COLUMN_NAME_CODE + " TEXT UNIQUE" +
        COMMA + COLUMN_NAME_MSG + " INTEGER NOT NULL DEFAULT 0" +
        " );";

当我使用相同数据更新记录时,更改的行数(受影响的行数)始终为 1。

SQLiteDatabase db = m_helper.getWritableDatabase();
String where = COLUMN_NAME_SID + "=" + sid;
ContentValues values = new ContentValues();
values.put(COLUMN_NAME_MSG, msg);
int rowsAffected = db.update(TABLE_NAME, values, where, null);
db.close();
// rowsAffected is always 1!

在其他 DBMS(如 Mysql)中,当我在特定记录上使用相同数据执行更新时,更改的行数为 0。在 Android 上的 SQLite 中是否不同?

4

1 回答 1

1

也许它只是无法识别该数据是否已实际更改。即使数据相同,任何查询都被视为更改。

好吧,这就是他们实施它的方式。例如,如果您在 IntellIJ IDE 中编写某些内容并将其删除,它不会显示文件已更改,但如果您在 Visual Studio 中执行此操作,它会显示,除非您执行了CTRL+Z. 这只是一种不同的实现方式。

于 2016-06-19T21:34:52.947 回答