欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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;

to_char和to_date的区别 

 有误语句如下:

(1)这样查不到数据,因为date类型的数据是精确到秒的。

select * from v_contact_order t
where t.mkt_campaign_id = 139534
and t.create_date = to_date(20191219,'yyyymmdd');

 to_char和to_date的区别

 (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’)

to_char和to_date的区别