0

我在 Android 上的 SQL 查询结果遇到了一些意外的不一致。

给定以下架构(非常简单):

public static final String TABLE_TOTD = "totd";
public static final String COLUMN_ID = "id";
public static final String COLUMN_TG = "tg";
public static final String COLUMN_EX = "ex";

private static final String DATABASE_NAME = "TOTD.db";

private static final String DATABASE_CREATE = "CREATE TABLE "
        + TABLE_TOTD + "("
            + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
            + COLUMN_TG + " TEXT NOT NULL, "
            + COLUMN_EX + " TEXT"
        + ");";

数据库正在初始化并填充了一些示例文本:

    SQLiteDatabase db = mdbHelper.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(MySQLiteHelper.COLUMN_TG, "This is a text (1)");
    values.put(MySQLiteHelper.COLUMN_EX, "Example goes here");

    db.insert(MySQLiteHelper.TABLE_TOTD, null, values);
    [...]

我在使用 SQLiteDatabase.query() 查询时检索到不一致的结果 以下代码通过返回带有表第一行的 Cursor 来完成预期的工作。

    String[] projection = null;
    String selection = "id = 1";
    String[] selectionArgs = null;
    Cursor cursor = db.query(
            MySQLiteHelper.TABLE_TOTD,
            projection,
            selection,
            selectionArgs,
            null, null, null);

selection通过像这样更改and ,它的工作原理完全相同selectionArgs

    String selection = "id = ?";
    String[] selectionArgs = {"1"};

但是现在,与预期不同的是,通过执行以下更改,返回的 Cursor 现在将为空:

    String selection = "? = ?";
    String[] selectionArgs = {"id", "1"};

实际上,尝试将任何不属于参数的内容推"1"送到参数中会导致查询返回一个空游标。

我尝试了以下方法:

    String selection = "? = 1";
    String[] selectionArgs = {"id"};

    String selection = "id ? 1";
    String[] selectionArgs = {"="};

    String selection = "?";
    String[] selectionArgs = {"id = 1"}; //This is where I couldn't take it anymore...

现在,我对任何形式的解释都持开放态度。我的代码有效,而且我知道我可以将所有参数放在selection字符串上,因为它们不包含任何禁止字符。我只想知道,为什么它不起作用,为什么没有提到开发人员文档的这个明确限制?

4

1 回答 1

0

selection 参数是WHERE您的 sqlite 查询的子句。当您使用 ? 执行查询时 它将在 selectionArgs 字符串数组中查找此参数。但是,您只能将值指定为 ? 而不是关键。几个有效的例子:

String selection = "id = ?";
String[] selectionArgs = new String[]{"1"};

类似于

String selection = "id = 1";
String[] selectionArgs = null;

但是你不能做

String selection = "? = ?";

您还可以指定多个 ? 在选择中。

String selection = "id = ? AND carId = ?";
String[] selectionArgs = new String[]{"1", "2"};

从文档中:

您可以在选择中包含 ?s,它将被 selectionArgs 中的值替换,以便它们出现在选择中。这些值将绑定为字符串。

http://developer.android.com/reference/android/database/sqlite/SQLiteDatabase.html#query(boolean, java.lang.String, java.lang.String[], java.lang.String, java.lang.字符串[]、java.lang.String、java.lang.String、java.lang.String、java.lang.String)

于 2015-04-07T23:36:14.393 回答