我表A中有个start_date的字段,正确的日期数据应该为20120412这种格式的,可是现在这个字段中有各种错误格式的数据,我想只要正确的日期数据,查询条件如何限定为正确的日期格式
如select * from A where。。=。。 省略号这边怎么写
比如有些错误数据为02012040,或者30120407,20121320 ,20120431,如何避开这些错误数据
日期前三位开头是201 的 那我的语句是
select * from A where
to_char(to_date(date,'yyyymmdd'),'yyyymmdd')=to_char(datea,'yyyymmdd') and
left(start_date3) = '201'
这样是吧?
如果是201的话,就是最小值为20100101,最大值是今天:
select * from A where start_date between to_date('20100101','yyyymmdd') and to_date('20130222','yyyymmdd');
TO_DATE不是sql的函数把,sql怎么改啊
追答你试试:
select * from A where start_date between cast('20100101' as datetime) and cast('20130222' as datetime);
从char数据类型到datetime数据类型的转换导致datetime值出界
追答试试这个函数:
select * from A where start_date between Convert(‘20100101’,Getdate(),112) and Convert(‘20130222’,Getdate(),112);
日期前三位开头是201 的 那我的语句是
select * from A where
to_char(to_date(date,'yyyymmdd'),'yyyymmdd')=to_char(datea,'yyyymmdd') and
left(start_date3) = '201'
这样是吧?