暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 数据类型转换之 varchar2,number,date

Oracle优化大师 2018-10-15
3754

    

 

       大家好;

       大家都知道,Oracle SQL 在where子查询中,“=” 关系的两侧,数据类型要一致,才能查询数据;有时候,我们不小心, Varchar2 “=”  Number; 虽然有时候不会提示【数据库设置选项】,但是Oracle 在查询之前,是会有隐形的数据类型转换的;

      在数据库查询引擎执行时,会多一步隐形数据转换;降低了查询性能,有时候还会破坏索引,是已经创建的索引无效;

      比如:

       表:cux_20_bd_Customers.customer_id 是varchar2,存储的纯数字;

      低效:

SELECT rc.customer_number,

              rc.customer_name

  FROM ra_customers        rc,

       cux_20_bd_customers r2

 WHERE 1 = 1

   AND r2.customer_id = rc.customer_id;-- 隐形数据转换


 r2.customer_id 会先转换成number,然后在连接;


      高效:

SELECT rc.customer_number,

               rc.customer_name

  FROM  ra_customers        rc,

              cux_20_bd_customers r2

 WHERE 1 = 1

   AND  to_number( r2.customer_id) = rc.customer_id;-- 显性数据转换;



若 r2.customer_id 有索引;则 索引被破坏;查询将全表扫描;



Oracle 中三大类型与隐式数据类型转换

 (1)varchar2变长/char定长-->number,例如:'123'->123

 (2)varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'

 (3)number---->varchar2/char,例如:123->'123'

 (4)date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'


Oracle 如何隐式转换:

1)“=”号二边的类型是否相同

2)如果“=”号二边的类型不同,尝试的去做转换

3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月



【1】查询1980年12月17日入职的员工(方式一:日期隐示式转换)

       select * from emp where hiredate = '17-12月-80';

【2】使用to_char(日期,'格"常量"式')函数将日期转成字符串,显示如下格式:2015 年 04 月 25 日 星期六

select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;

【3】使用to_char(日期,'格式')函数将日期转成字符串,

         显示如格式:2015-04-25今天是星期六 15:15:15

 select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss') from dual;

select to_char(sysdate,'yyyy-mm-dd"今天是"day HH12:MI:SS AM') from dual;

【4】使用to_char(数值,'格式')函数将数值转成字符串,

显示如下格式:$1,234

 select to_char(1234,'$9,999') from dual;

【5】使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234select to_char(1234,'$9,999') from dual;

 select to_char(1234,'L9,999') from dual;

【6】使用to_date('字符串','格式')函数,查询1980年12月17日入职的员工(方式二:日期显式转换)

select * from emp where hiredate = 

to_date('1980年12月17日','yyyy"年"mm"月"dd"日"');

select * from emp where hiredate = 

to_date('1980#12#17','yyyy"#"mm"#"dd');

select * from emp where hiredate =

 to_date('1980-12-17','yyyy-mm-dd');

【7】使用to_number('字符串')函数将字符串‘123’转成数字123

 select to_number('123') from dual;

注意:

select '123' + 123 from dual;

结果:246

 

select '123' || 123 from dual;

结果:123123


      今天到此为止,希望对大家有帮助;


下期更精彩;





本文分享自微信公众号 - Oracle优化大师,如有侵权,请联系 service001@enmotech.com 删除。
文章转载自Oracle优化大师,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论