SQL在查询日期数据时如何限定查询的日期格式

我表A中有个start_date的字段,正确的日期数据应该为20120412这种格式的,可是现在这个字段中有各种错误格式的数据,我想只要正确的日期数据,查询条件如何限定为... 我表A中有个start_date的字段,正确的日期数据应该为20120412这种格式的,可是现在这个字段中有各种错误格式的数据,我想只要正确的日期数据,查询条件如何限定为正确的日期格式

如select * from A where。。=。。 省略号这边怎么写
比如有些错误数据为02012040,或者30120407,20121320 ,20120431,如何避开这些错误数据
展开
 我来答
二楼最厉害
2013-02-22 · TA获得超过4345个赞
知道小有建树答主
回答量:288
采纳率:50%
帮助的人:236万
展开全部
像楼上的回答可能会出现 一种情况,如30120407 也会被认为转成3012年4月7号,这样肯定是不合适的,建议你找个最小的年份,或者编造一个最小和最大的年份:现在是2013年2月22日为最大值,然后定义你表里实际的最小值2011年1月1日:

你的start_date为date类型的sql:
select * from A where start_date between

to_date('20110101','yyyymmdd') and to_date('20130222','yyyymmdd');
更多追问追答
追问
日期前三位开头是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');
dngoryaner
2013-02-22 · TA获得超过2350个赞
知道小有建树答主
回答量:2404
采纳率:0%
帮助的人:1127万
展开全部
select * from A where
to_char(to_date(date,'yyyymmdd'),'yyyymmdd')=to_char(datea,'yyyymmdd');
追问
日期前三位开头是201 的 那我的语句是
select * from A where
to_char(to_date(date,'yyyymmdd'),'yyyymmdd')=to_char(datea,'yyyymmdd') and
left(start_date3) = '201'

这样是吧?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
szm341
2013-02-22 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5125万
展开全部
sqlserver:
where isdate(col)=1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式