为什么ORDER BY不能在Sqlite查询中工作

时间:2016-10-19 11:10:19

标签: android sqlite

在Android中创建Sqlite表:

// Contacts table name
private static final String TABLE_CHAL = "CD";

// Contacts Table Columns names
private static final String KEY_ID = "id";
private static final String KEY_CHAL = "chal";
private static final String KEY_DATE = "date";

String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_CHAL + "("
        + KEY_ID + " INTEGER PRIMARY KEY," + KEY_CHAL + " TEXT,"
        + KEY_DATE + " TEXT)";
db.execSQL(CREATE_CONTACTS_TABLE);

查询(按KEY_DATE排序):

Cursor cursor = db.rawQuery("SELECT * FROM " + TABLE_CHAL + " ORDER BY [" + KEY_DATE + "] ASC", null);

上述情况似乎无效。

我必须在执行订单之前将KEY_DATE转换为日期。

3 个答案:

答案 0 :(得分:2)

您可以使用

SELECT * FROM cd ORDER BY datetime(substr(date, 7, 4) || '-' || substr(date, 4, 2) || '-' || substr(date, 1, 2))

答案 1 :(得分:0)

尝试用此替换你的:

Cursor cursor = db.rawQuery("SELECT * FROM " + TABLE_CHAL + " ORDER BY " + KEY_DATE + "ASC", null);

答案 2 :(得分:0)

我使用现有的KEY_DATE列创建了一个新列,并以yyyy-mm-ddd格式保存。然后我将查询更新为date("+KEY_FORMAT_DATE+")";,这对我有用。