在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
转换为日期。
答案 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+")";
,这对我有用。