在android中使用sqlite的strftime函数

Man*_*ano 4 sqlite android 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')
Run Code Online (Sandbox Code Playgroud)

它工作得很好。

另一方面,当我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')
Run Code Online (Sandbox Code Playgroud)

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

谢谢你。

小智 5

在您的第二个语句中,strftime提供了一个无效的timestring. 这会导致函数返回NULL

sqlite> .nullvalue <NULL>
sqlite> select strftime('%Y-%m','2013-02');
<NULL>
Run Code Online (Sandbox Code Playgroud)

只需将日期添加到您提供的日期,它就会正常工作:

sqlite> select strftime('%Y-%m','2013-02-01');
2013-02
Run Code Online (Sandbox Code Playgroud)

您可以在此处找到有效timestring格式的列表。