黄东旭解析 TiDB 的核心优势
1366
2023-05-12
详解***中三大类型与隐式数据类型转换
在某些情况下,*** Server 会收到数据类型与预期的数据类型不同的数据。发生这种情况时,*** Server 可自动将该数据转换为预期的数据类型。这种数据类型转换可以由*** Server 隐式完成,也可以由用户显式完成。
在MySQL跟***中,如果存在隐式的数据类型转换,可能导致无法命中索引,从而进行全表扫描的危险。
一、类型转换规则
MySQL类型转换规则:
两个参数至少有一个是NULL时,比较的结果也是 NULL,例外是使用 <=> 对两个NULL做比较时会返回1,这两种情况都不需要做类型转换两个参数都是字符串,会按照字符串来比较,不做类型转换两个参数都是整数,按照整数来比较,不做类型转换十六进制的值和非数字做比较时,会被当做二进制串有一个参数是TIMESTAMP或DATETIME,并且另外一个参数是常量,常量会被转换为timestamp所有其他情况下,两个参数都会被转换为浮点数再进行比较
***类型转换规则:
对于insert和update操作,***将值转换为受影响的的列的类型。对于SELECT操作,***会将列的值的类型转换为目标变量的类型。
二、***中三大类型与隐式数据类型转换
varchar2变长/char定长-->number,例如:'123'->123varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'number---->varchar2/char,例如:123->'123'date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'
三、***/MySQL如何隐式转换
=号二边的类型是否相同如果=号二边的类型不同,尝试的去做转换在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月
四、***隐式转换实例
(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
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。