to_char和to_date的区别
程序员文章站
2022-04-21 14:59:55
...
to_char和to_date的区别
TO_CHAR : 是把日期或者数字转换为字符串
TO_DATE : 是把字符串转换为数据库中的日期类型
具体的区别就是上述两条了,往下的细分,其他博客讲的很清楚了,下面我说一下我的问题。
从数据库中查询某一天的具体数据
eg:从工单表里查出活动id为139534的当天数据(我查的那天是2019/12/19)
工单表:v_contact_order
活动id: mkt_campaign_id
创建时间: create_date (date型)
查询正确语句如下:
select * from v_contact_order t
where t.mkt_campaign_id = 139534
and to_char(t.create_date,’yyyymmdd’) = 20191219;
有误语句如下:
(1)这样查不到数据,因为date类型的数据是精确到秒的。
select * from v_contact_order t
where t.mkt_campaign_id = 139534
and t.create_date = to_date(20191219,'yyyymmdd');
(2)这样查询,查询速度太慢(表里有一万多的数据,我没有等查询结束)
SELECT * FROM V_CONTACT_ORDER T
WHERE T.CREATE_DATE BETWEEN TO_DATE(‘2019-12-18 23:59’,’YYYY-MM-DD HH24:MI:SS’)
AND TO_DATE(‘2019-12-19 23:59’,’YYYY-MM-DD HH24:MI:SS’)