4

在我的 DBHelper 的 getEvents 方法中有这行代码。

    int year, month, day;
    String[] columns = new String[] { KEY_EVENTNAME, KEY_DESCRIPTION,
            KEY_HOUR, KEY_MINUTE, KEY_DAY, KEY_MONTH, KEY_YEAR,
            KEY_REMINDER };
    Cursor c = database.query(DATABASE_TABLE, columns, 
            KEY_YEAR + "=?"+ " AND " + KEY_MONTH + "=?" + " AND "+ KEY_DAY + "=?",
            new String[] {String.valueOf(year), String.valueOf(month), String.valueOf(day)}, 
            null, null, KEY_MONTH + " AND "
            + KEY_DAY);

它总是什么都不返回。当我删除以下内容时

    int year, month, day;
    String[] columns = new String[] { KEY_EVENTNAME, KEY_DESCRIPTION,
            KEY_HOUR, KEY_MINUTE, KEY_DAY, KEY_MONTH, KEY_YEAR,
            KEY_REMINDER };
    Cursor c = database.query(DATABASE_TABLE, columns, 
            KEY_YEAR + "=?",
            new String[] {String.valueOf(year)}, 
            null, null, KEY_MONTH + " AND "
            + KEY_DAY);

它运行正确。我的代码有什么问题?似乎它不接受多个值作为 where 子句。谁能帮我这个?谢谢。

4

3 回答 3

15

答案就在标题中:您试图将整数值传递到查询中,但实际上最终得到的是字符串值。

这是 Android 数据库 API 中的一个可怕的设计错误;您只能将参数用于字符串。

整数没有字符串值会出现的格式和 SQL 注入问题,因此您可以直接将数字插入 SQL 表达式:

Cursor c = database.query(
    DATABASE_TABLE, columns, 
    KEY_YEAR  + "=" + year  + " AND " +
    KEY_MONTH + "=" + month + " AND " +
    KEY_DAY   + "=" + day,
    null, null, null,
    KEY_MONTH + "," + KEY_DAY);

(而且orderBy语法错误。)

于 2013-09-11T19:18:19.693 回答
1

我看不出语法或逻辑有什么问题。尝试检查年、月和日的值是否正确。

于 2013-09-11T16:20:49.953 回答
0

谢谢你的帮助。在考虑了你建议的一切之后,我终于找到了为什么它总是什么都不返回的原因。我传递给此方法的月份值不正确。提前一个月,这就是为什么当月返回 0 的原因。我很抱歉给您带来麻烦。但你所有的答案都是正确的。这是我相信大多数人或一些人都经历过的错误。作为一项学习,我会格外小心地研究我通过的价值观。仔细查看在方法之间传递的值流可以节省时间。我整晚都在寻找问题,就在今天早上醒来后,我想起了传递给方法的值。再次感谢所有给出答案的人。

于 2013-09-12T01:22:49.520 回答