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

发布时间:2025-05-25 01:47:20 作者:益华网络 来源:undefined 浏览量(0) 点赞(0)
摘要:在某些情况下,Oracle Server 会收到数据类型与预期的数据类型不同的数据。发生这种情况时,Oracle Server 可自动将该数据转换为预期的数据类型。这种数据类型转换可以由Oracle Server 隐式完成,也可以由用户显式完成。 在MySQL跟Oracle中,如果存在隐式的数据类型转换,可能导致无法命中索

在某些情况下,Oracle Server 会收到数据类型与预期的数据类型不同的数据。发生这种情况时,Oracle Server 可自动将该数据转换为预期的数据类型。这种数据类型转换可以由Oracle Server 隐式完成,也可以由用户显式完成。

在MySQL跟Oracle中,如果存在隐式的数据类型转换,可能导致无法命中索引,从而进行全表扫描的危险。

一、类型转换规则

MySQL类型转换规则:

两个参数至少有一个是NULL时,比较的结果也是 NULL,例外是使用 <=> 对两个NULL做比较时会返回1,这两种情况都不需要做类型转换 两个参数都是字符串,会按照字符串来比较,不做类型转换 两个参数都是整数,按照整数来比较,不做类型转换 十六进制的值和非数字做比较时,会被当做二进制串 有一个参数是TIMESTAMP或DATETIME,并且另外一个参数是常量,常量会被转换为timestamp 所有其他情况下,两个参数都会被转换为浮点数再进行比较

Oracle类型转换规则:

对于insert和update操作,oracle将值转换为受影响的的列的类型。 对于SELECT操作,oracle会将列的值的类型转换为目标变量的类型。

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

varchar2变长/char定长-->number,例如:123->123 varchar2/char-->date,例如:25-4月-15->25-4月-15 number---->varchar2/char,例如:123->123 date------>varchar2/char,例如:25-4月-15->25-4月-15

三、Oracle/MySQL如何隐式转换

=号二边的类型是否相同 如果=号二边的类型不同,尝试的去做转换 在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月

四、Oracle隐式转换实例

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

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

(2) 使用to_char(日期,格"常量"式)函数将日期转成字符串)

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

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

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(数值,格式)函数将数值转成字符串

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

(5) 使用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); 

(6) 使用to_number(字符串)函数将字符串‘123’转成数字123

select to_number(123) from dual; 

注意:

select 123 + 123 from dual;246 select 123 || 123 from dual;123123 

二维码

扫一扫,关注我们

声明:本文由【益华网络】编辑上传发布,转载此文章须经作者同意,并请附上出处【益华网络】及本页链接。如内容、图片有任何版权问题,请联系我们进行处理。

感兴趣吗?

欢迎联系我们,我们愿意为您解答任何有关网站疑难问题!

您身边的【网站建设专家】

搜索千万次不如咨询1次

主营项目:网站建设,手机网站,响应式网站,SEO优化,小程序开发,公众号系统,软件开发等

立即咨询 15368564009
在线客服
嘿,我来帮您!