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格式的列表。
| 归档时间: |
|
| 查看次数: |
8649 次 |
| 最近记录: |