加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

详解Oracle中三大范例与隐式数据范例转换

发布时间:2019-10-01 12:26:14 所属栏目:编程 来源:波波说运维
导读:在某些环境下,Oracle Server 会收到数据范例与预期的数据范例差异的数据。产生这种环境时,Oracle Server 可自动将该数据转换为预期的数据范例。这种数据范例转换可以由Oracle Server 隐式完成,也可以由用户显式完成。 在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中三大范例与隐式数据范例转换

【编辑保举】

  1. 深入分解 MySQL 索引和 SQL 调优拭魅战
  2. MySQL数据库监控指标之执行机能总结
  3. 详解MySQL数据库监控指标之毗连状态
  4. 高并发情形下怎样让Redis和MySQL保持数据同一
  5. 阿内里试MySQL魂灵拷问20题,Java措施员秋招必会的8个常识点
【责任编辑:赵宁宁 TEL:(010)68476606】
点赞 0

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读