加入收藏 | 设为首页 | 会员中心 | 我要投稿 唐山站长网 (https://www.0315zz.com.cn/)- 数据安全、数据开发、文字识别、图像处理、媒体智能!
当前位置: 首页 > 站长资讯 > 传媒 > 正文

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

发布时间:2021-03-16 14:13:37 所属栏目:传媒 来源:互联网
导读:MySQL跟Oracle中,如果存在隐式的数据类型转换,可能导致无法命中索引,从而进行全表扫描的危险。 一、类型转换规则 MySQL类型转换规则: 两个参数至少有一个是NULL时,比较的结果也是 NULL,例外是使用 = 对两个NULL做比较时会返回1,这两种情况都不需要做

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

(编辑:唐山站长网)

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

    推荐文章
      热点阅读