4

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

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

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')

不会工作。为什么会发生,我该如何解决?

谢谢你。

4

1 回答 1

5

在您的第二个语句中,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格式的列表。

于 2012-08-30T09:22:39.647 回答