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

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

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

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

在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日入职的员工(方式一:日期隐示式转换)

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

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

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

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

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

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

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

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

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

  1. select to_char(1234,'$9,999') from dual;  
  2. select to_char(1234,'L9,999') from dual; 

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

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

  1. select * from emp where hiredate = to_date('1980年12月17日','yyyy"年"mm"月"dd"日"'); 

  1. select * from emp where hiredate = to_date('1980#12#17','yyyy"#"mm"#"dd'); 

  1. select * from emp where hiredate = to_date('1980-12-17','yyyy-mm-dd'); 

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

  1. select to_number('123') from dual; 

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

注意:

  1. select '123' + 123 from dual;246 
  2. select '123' || 123 from dual;123123 

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

 

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2017-12-20 14:14:16

数据库MySQL数据类型

2010-04-13 12:56:16

Oracle字符集

2017-09-13 10:58:51

JavaScript转换规则

2017-09-05 16:17:35

JavaScript运算转换

2010-05-12 14:05:54

MySQL安装

2010-03-30 16:33:55

Oracle数据类型

2019-11-29 07:37:44

Oracle数据库索引

2010-04-21 15:10:14

Oracle数据类型

2010-06-17 23:31:35

协议转换器

2010-04-02 13:15:01

Oracle跟踪

2023-08-14 08:35:36

2009-11-17 10:01:11

Oracle数据类型

2022-06-20 08:26:39

Spring容器类型转换

2020-12-29 07:56:23

JavaScript数据类型 primitive

2010-01-05 14:04:53

.NET Framew

2024-03-14 11:54:37

C++数据类型

2023-04-06 07:49:23

Python数据类型

2011-04-13 09:16:55

泛型

2010-08-25 13:36:53

DB2Oracle

2022-10-27 20:42:04

JavaScripJava编程语言
点赞
收藏

51CTO技术栈公众号