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’)
本文详细对比了TO_CHAR和TO_DATE在Oracle数据库中的使用区别,前者用于将日期或数字转换为字符串,后者则将字符串转换为日期类型。通过具体案例说明了如何正确查询特定日期的数据,避免常见错误,如直接比较日期与字符串形式的日期,以及提高查询效率。
2083

被折叠的 条评论
为什么被折叠?



