簡體   English   中英

android:SQLite查詢之間的條件問題

[英]android: SQLite query with between condition problem

我有一個具有這樣的架構的表:

        db.execSQL("CREATE TABLE TBL_REMINDERS (" //
                + "FLD_YEAR INTEGER, " //
                + "FLD_MON INTEGER, " //
                + "FLD_DATE INTEGER, " //
                + "FLD_HOUR INTEGER, " //
                + "FLD_MIN INTEGER, " //
                + "FLD_EVENT TEXT" //
                + ")" //

其中FLD_MON字段的范圍為[1,12],FLD_DATE [1,31],FLD_HOUR [0,23],FLD_MIN [0,59]

並且針對下表的rawQuery不會返回任何結果集:

public List<Reminder> getRemindersBetween(int y1, int m1, int d1, int h1, int min1, int y2, int m2, int d2, int h2,
        int min2) {
    String sql = "SELECT FLD_YEAR, FLD_MON, FLD_DATE, FLD_HOUR, FLD_MIN, FLD_EVENT FROM TBL_REMINDERS "//
            + "WHERE (100000000 * FLD_YEAR + 1000000 * FLD_MON + 10000 * FLD_DATE + 100 * FLD_HOUR + FLD_MIN BETWEEN ? AND ?) " //
            + "ORDER BY FLD_YEAR, FLD_MON, FLD_DATE, FLD_HOUR, FLD_MIN, FLD_EVENT ";
    SQLiteDatabase db = null;
    Cursor cur = null;
    try {
        db = new CalendarDBOpenHelper(context).getReadableDatabase();
        cur = db.rawQuery(sql, new String[] { "" + (100000000 * y1 + 1000000 * m1 + 10000 * d1 + 100 * h1 + min1),//
                "" + (100000000 * y2 + 1000000 * m2 + 10000 * d2 + 100 * h2 + min2 - 1) //
        });
        List<Reminder> list = new ArrayList<Reminder>();
        while (cur.moveToNext()) {
            int year = cur.getInt(0);
            int mon = cur.getInt(1);
            int date = cur.getInt(2);
            int hour = cur.getInt(3);
            int min = cur.getInt(4);
            String event = cur.getString(5);
            list.add(new Reminder(year, mon, date, hour, min, event));
        }

        return list;
    } finally {
        if (null != cur) {
            try {
                cur.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        if (null != db) {
            try {
                db.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

而下面的另一個rawQuery可以正常工作:

public List<Reminder> getRemindersOfDate(int y, int m, int d) {
    String sql = "SELECT FLD_HOUR, FLD_MIN, FLD_EVENT FROM TBL_REMINDERS "//
            + "WHERE FLD_YEAR=? AND FLD_MON=? AND FLD_DATE=? " //
            + "ORDER BY FLD_HOUR, FLD_MIN, FLD_EVENT";

    SQLiteDatabase db = null;
    Cursor cur = null;

    try {
        db = new CalendarDBOpenHelper(context).getReadableDatabase();
        cur = db.rawQuery(sql, new String[] { "" + y, "" + m, "" + d });

        List<Reminder> reminders = new ArrayList<Reminder>();
        while (cur.moveToNext()) {
            int hour = cur.getInt(0);
            int min = cur.getInt(1);
            String event = cur.getString(2);
            reminders.add(new Reminder(y, m, d, hour, min, event));
        }
        return reminders;
    } finally {
        if (null != cur) {
            try {
                cur.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        if (null != db) {
            try {
                db.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    } // finally
}

我猜這是“介於...和...之間”的條件,這很麻煩,因為這是兩個SQL查詢之間的唯一區別。 但我不確定

編輯:

事情變得越來越有趣。 我現在確定問題是由where子句中的表達式引起的。 在上面的第二種方法中,如果我修改

            + "WHERE FLD_YEAR=? AND FLD_MON=? AND FLD_DATE=? " //

            + "WHERE 10 * FLD_YEAR=? AND FLD_MON=? AND FLD_DATE=? " //

以及

        cur = db.rawQuery(sql, new String[] { "" + (10 * y), "" + m, "" + d });

那我什么也沒得到

首先,他們肯定是不同的。

第一個在特定時間范圍內返回匹配的條目。
第二個返回條目,其中月份,年份和日期具有給定的值。

編輯

嘗試對表達式使用大括號,因此(10 * FLD_YEAR)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM