怪异的sqlite3日期格式

感觉sqlite3的日期格式很怪异,所以用sqliteman建了一个测试表,代码如下:createtable'test'('dt'date);deletefromtest... 感觉sqlite3的日期格式很怪异,所以用sqliteman建了一个测试表,代码如下:
create table 'test' ('dt' date);
delete from test;
insert into test values ('2012-03-01');
insert into test values ('2012-01-01');
insert into test values ('2012-06-01');
select * from test where dt between '2012-02-01' and '2012-03-31';
-- 返回‘2012-03-01’是正确的结果;
select * from test where dt between '2012-2-01' and '2012-03-31';
-- 返回空集;
select * from test where dt between '2012-02-01' and '2012-03-31';
-- 返回'2012-06-01'和'2012-03-01‘显然多返回了一条;

请问这些应该如何解释?是否sqlite的日期格式只接受"YYYY-MM-DD“的类型,否则就会出现不正常的结果?
展开
 我来答
tim_spac
推荐于2016-07-29 · TA获得超过3628个赞
知道大有可为答主
回答量:1804
采纳率:100%
帮助的人:2021万
展开全部
sqlite 是弱数据类型, 它不能按你指定的数据类型进行自动数据转换;
你输入的这些日期数据记录下来的实际是字符串, 这些数据的比较是按照字符比较进行的。
如果要按日期进行处理, 请在应用中转换后再存储到sqlite数据库中。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式