我找不到解决我的问题的办法。
我有一个HTML5 Web SQL数据库,其中的表如下所示:
db.transaction(function(tx) {
tx.executeSql("CREATE TABLE IF NOT EXISTS todo " +
"(todoId INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, " +
"note VARCHAR(100) NOT NULL, " +
"state VARCHAR(100) NOT NULL, " +
"todoDate DATETIME NOT NULL)");
});当我向这个数据库添加值(notation = dd-MM-yyyy)时,todoDate看起来像是作为字符串添加到数据库中。当我使用下面的查询从数据库中收集和排序一些todoDate值时,这些值的排序顺序是错误的:
sql = "select * FROM todo order by todoDate asc";输出:
todoId - note - state - todoDate
3 - blabla - someinfo - 01-01-2013
1 - blabla - someinfo - 22-09-2012
2 - blabla - someinfo - 25-10-2012我想要得到以下订单:
todoId - note - state - todoDate
1 - blabla - someinfo - 22-09-2012
2 - blabla - someinfo - 25-10-2012
3 - blabla - someinfo - 01-01-2013我如何才能做到这一点?
我找到了函数str_to_date,但它不起作用,或者我做错了什么。
提前感谢!
发布于 2012-09-27 21:59:25
我找到了解决方案。
代码如下:
SELECT * FROM tablename ORDER by substr(dateColumn,7)||substr(dateColumn,4,2)||substr(dateColumn,1,2);发布于 2012-11-15 04:22:55
HTML5 Web SQL数据库实际上是幕后的SQLite。SQLite doesn't have a DATETIME type。如果你向它们发送字符串,它会将它们存储为字符串。SQLite建议您使用ISO-8601规范格式(例如"2012-09-22"),以便进行预期的比较。SQLite提供了一组有用的日期时间函数,用于处理数据库中的日期时间值。参见here。或者,您可以存储毫秒,但我个人更喜欢存储字符串,因为它们是人类可读的,这有助于调试。
发布于 2012-09-27 20:15:16
Like that query you can fire :
select * from (select column1,...,convert(date,column) from table) as a order by dateColumnhttps://stackoverflow.com/questions/12620727
复制相似问题