现Oracle数据库中有一个表T,表中的字段有T_name,T_sex,T_date
其中T_date的数据类型为varchar2,录入的时间格式多样:
2018-08-01 00:00:00
2018-8-1 9:00:00
2018-8-01 9:00:00
2018-08-1 9:00:00
2018/8/1
2018/08/01 00:00:00
2018/8/1 9:00:00
2018/8/1
2018-10-24 星期日 下午 9:00:00
2018-10-24 星期日 下午 23:00:00
且较多的为:2018-08-01 00:00:00
2018-8-1 9:00:00
2018-8-01 9:00:00
2018-08-1 9:00:00
2018/8/1
2018/08/01 00:00:00
2018/8/1 9:00:00
2018/8/1 ,几万条里会有那么3-4个,2018-10-24 星期日 下午 9:00:00
2018-10-24 星期日 下午 23:00:00.
问:如何查询出字段T_date 中日期大于2018年3月1日的所有数据,最低限度是要查出除了含有2018-10-24 星期日 下午 9:00:00
2018-10-24 星期日 下午 23:00:00这两种格式的所有数据
select *
from (select replace(replace(replace(t.T_dateFormat, '/'), ' '),
':') T_dateFormat,
t.T_date,
t.T_name,
t.T_sex
from (select case
when t.T_date like '%/%' then
to_char(TO_DATE(t.T_date,
'YYYY/MM/DD HH24:MI:SS'),
'YYYY/MM/DD HH24:MI:SS')
when t.T_date like '%-%' then
to_char(TO_DATE(t.T_date,
'YYYY/MM/DD HH24:MI:SS'),
'YYYY/MM/DD HH24:MI:SS')
end as T_dateFormat,
t.T_date,
t.T_name,
t.T_sex
from T t
where t.T_date not like '%星期%') t) t
where t.T_dateFormat > '20180301000000'
SELECT *
FROM T
WHERE TO_CHAR (TO_DATE (T_date, 'YYYY-MM-DD HH24:MI:SS'),
'YYYY/MM/DD HH24:MI:SS') >
TO_CHAR ('2018-03-01 00:00:00', 'YYYY/MM/DD HH24:MI:SS');
这样查询会查出除了含有中文字符如“2018-10-24 星期日 下午 9:00:00”类型的所有你想要的数据,但是这样效能会比较差。
最好建立该表的时候T_DATE建成DATE类型的,在一开始程序写入该字段的时候就做好处理。
SELECT * FROM (select T.*,to_char(to_date(T_date,'yyyy-MM-dd hh24:mi:ss'),'yyyy-MM-dd hh24:mi:ss') AS NEWDATE FROM T where T_date not like '%星期%') INFODB WHERE NEWDATE>'2018-03-01 23:59:59'
其实吧,这个建议写个函数,遍历所有已知的格式,对传入的字符串进行to_date,报错就换下一种格式,转成功了就return你想要的格式