Oracle数据库中如何查询日期大于2018年3月1日的所有数据

现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这两种格式的所有数据

3个回答

    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'
qq_42009260
qq_42009260 谢谢大佬
12 个月之前 回复

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类型的,在一开始程序写入该字段的时候就做好处理。

qq_42009260
qq_42009260 这个查询的话会报错 ora 01722无效数字
12 个月之前 回复

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'

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!