在android中使用sqlite的strftime函数

时间:2012-08-30 09:15:54

标签: android sqlite strftime

您好我在我的数据库中插入了一些日期。

当我执行查询时,如果我在另一个表格中使用YYY-MM-DD格式的sqlite3

SELECT * 
FROM SDay 
WHERE  strftime('%Y-%m-%d', date)>=strftime('%Y-%m-%d','2013-02-21')
    AND  strftime('%Y-%m-%d', date)<strftime('%Y-%m-%d','2013-09-15')

它运作得很好。

另一方面,当我在另一个表格中使用格式YYY-MM

SELECT * 
FROM SMonth 
WHERE  strftime('%Y-%m', date)>=strftime('%Y-%m','2013-02') 
    AND  strftime('%Y-%m', date)<strftime('%Y-%m','2013-09')

不会起作用。为什么会发生这种情况?我该如何解决?

谢谢。

1 个答案:

答案 0 :(得分:4)

在您的第二个声明中,strftime提供了无效的timestring。这会导致函数返回NULL

sqlite> .nullvalue <NULL>
sqlite> select strftime('%Y-%m','2013-02');
<NULL>

只需将日期添加到您提供的日期即可正常运行:

sqlite> select strftime('%Y-%m','2013-02-01');
2013-02

您可以找到有效timestring格式here的列表。