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

    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你想要的格式