|
|
|
|
移动端

沙龙国际在线博彩:详解Oracle中三大类型与隐式数据类型转换

本文来源:http://www.344078.com/hb_qq_com/

www.86msc.com,这条微博转发已经超出9000了,看来苍老师也是深得民心。正是在这个时期,全国人大财政经济委员会、国家经济贸易委员会(2003年在国务院机构改革中被裁撤)等国内机关开始有意识地与国际破产从业员协会(INSOLInternational)、亚洲发展银行、世界银行、德国技术合作公司(GTZ,代表德国联邦经济合作与发展部)等国际金融机构与法律全球化组织在破产立法问题上展开合作。借用Teubner的“自创生系统”理论话语,我国的法律系统——包括独立性已经较强的商法系统——仍然处于自治性较低,无法完全排斥外界环境干预、更无力规制其他社会子系统的状态。  获悉儿子可能并非真凶后,聂树斌之母张焕枝走上了漫漫申诉路。

北京一家大型券商策略分析师向21世纪经济报道记者表示。累积投票制是指上市公司股东大会选举董事或监事时,有表决权的每一普通股股份拥有与所选的董事或监事人数相同的表决权,股东拥有表决权可以集中使用。这些企业会有几方面,一方面是成本,在去年2012年控制的比较好,会导致它后期的压力会更小一些。拉比说:“这就是面孔在VR里闪亮的部分。

微博股价上周上涨19%,与此同时,投资者借入用于做空微博的股票数量增至创纪录的400万股。相比之下,新能源车需要让汽车随时保持电量充足,因此也需要精确判断出用户的使用习惯、车辆停放位置、城市通行的潮汐等数据分析出充电桩安放位置。不过,阿里巴巴西溪园区里那家据说在中国业绩最好的星巴克门店,依然不支持微信支付。“他是有目的去做推广的。

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

作者:波波说运维来源:今日头条|2019-09-28 22:41

在某些情况下,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
分享:
大家都在看
猜你喜欢

订阅专栏+更多

用Python玩转excel

用Python玩转excel

让重复操作傻瓜化
共3章 | DE8UG

175人订阅学习

AI入门级算法

www.86msc.comAI入门级算法

算法常识
共22章 | 周萝卜123

157人订阅学习

这就是5G

这就是5G

5G那些事儿
共15章 | armmay

128人订阅学习

读 书 +更多

设计模式:可复用面向对象软件的基础(双语版)

《设计模式:可复用面向对象软件的基础》(双语版)是引导读者走入软件设计迷宫的指路明灯,凝聚了软件开发界几十年的设计经验。四位顶尖的...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微

菲律宾太阳娱乐官方网址 申博在线娱乐登入网址 菲律宾申博手机app版直营网 菲律宾申博游戏登入 申博会员登入 www.99psb.com
www.55msc.com 申博138微信支付充值 申博代理官网登入 www.xpj8.com 申博支付宝充值 申博手机版下载登入
申博登录网址 申博官网太阳城娱乐网 申博管理网登入 申博娱乐城直营网 太阳城申博桌面安装版下载 www.9646.com