如何在android上的Query中添加WHERE子句

时间:2010-07-17 13:53:07

标签: android sqlite where-clause

我想将结果限制为KEY_HOMEID等于journalId的结果。 我已经在这几天了,任何帮助都会受到赞赏。

public Cursor fetchAllNotes(String journalId) {      return mDb.query(DATABASE_TABLE, new String[] {KEY_ROWID, KEY_HEIGHT, KEY_BODY, KEY_HOMEID},"FROM DATABASE_TABLE WHERE KEY_HOMEID = journalId",null, null, null, null,null); }

3 个答案:

答案 0 :(得分:25)

查看http://developer.android.com/reference/android/database/sqlite/SQLiteDatabase.html#query

您的查询应该看起来像这样:

mDb.query(DATABASE_TABLE, // Table name
          columnNames, // String[] containing your column names
          KEY_HOMEID+" = "+jounalId, // your where statement, you do not include the WHERE or the FROM DATABASE_TABLE parts of the query,
          null,
          null,
          null,
          null
         );

如果您对编写SQL查询感觉更舒服,也可以使用:

mDb.rawQuery("SQL STATEMENT", null);

答案 1 :(得分:8)

如果您在参数(在查询参数中)使用它,它会使您的代码更加清晰 例如:

        String [] settingsProjection = {
                DBContract.Settings._ID,
                DBContract.Settings.COLUMN_NAME_USER_ID,
                DBContract.Settings.COLUMN_NAME_AUTO_LOGIN
        };

        String whereClause = DBContract.Settings.COLUMN_NAME_USER_ID+"=?";
        String [] whereArgs = {userId.toString()};

        Cursor c = db.query(
                DBContract.Settings.TABLE_NAME,
                settingsProjection,
                whereClause,
                whereArgs,
                null,
                null,
                null
        );

答案 2 :(得分:2)

我也在寻找问题的答案。

事实证明我尝试使用String而不是Integer。我的解决方案是这样做:'String'而不是Integer。

以下是最终对我有用的代码:

return db.query(TABLE_NAME_REMINDER, PROJECTION, REMINDER_REMINDER_TYPE+" = '"+rem_type+"'", null, null, null, null);