qq_42009260
qq_42009260
采纳率50%
2018-12-06 05:06

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条回答

  • zhongsan123 才沐木 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'
    
    点赞 评论 复制链接分享
  • tkzd2005 tkzd2005 3年前

    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'

    点赞 评论 复制链接分享
  • weixin_40780360 水墨君123 3年前

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

    点赞 评论 复制链接分享

相关推荐