扫码关注官方订阅号
欢迎选择我的课程,让我们一起见证您的进步~~
下面来分析一下隐式转换的规则:
两个参数至少有一个是 NULL 时,比较的结果也是 NULL,例外是使用 <=> 对两个 NULL 做比较时会返回 1,这两种情况都不需要做类型转换
两个参数都是字符串,会按照字符串来比较,不做类型转换
两个参数都是整数,按照整数来比较,不做类型转换
十六进制的值和非数字做比较时,会被当做二进制串
有一个参数是 TIMESTAMP 或 DATETIME,并且另外一个参数是常量,常量会被转换为 timestamp
有一个参数是 decimal 类型,如果另外一个参数是 decimal 或者整数,会将整数转换为 decimal 后进行比较,如果另外一个参数是浮点数,则会把 decimal 转换为浮点数进行比较
所有其他情况下,两个参数都会被转换为浮点数再进行比较
与题主相关的只有最后一条:问题可以简单归纳像如下的情况:
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; INSERT INTO `user` (`id`) VALUES (123);
mysql> SELECT * FROM USER WHERE id IN ( '123-1' ,'124-1' ); +-----+ | id | +-----+ | 123 | +-----+
等价于:
SELECT * FROM USER WHERE id = '123-1' or id = '124-1';
id是int类型,参数是字符类型,不同类型比较的过程中,会发生上述的mysql隐式类型转换,两个参数都会被转换为浮点数再进行比较。
mysql> select '123-1'=123; +-------------+ | '123-1'=123 | +-------------+ | 1 | +-------------+ 1 row in set, 1 warning (0.00 sec)
'123-1'转换成浮点类型是:
mysql> select '123-1'+0.0; +-------------+ | '123-1'+0.0 | +-------------+ | 123 | +-------------+ 1 row in set, 1 warning (0.00 sec)
我们看到'123-1'和123转换成浮点型后数值上是相等的,所以由于 MySQL 隐式类型转换规则比较复杂,依赖 MySQL 隐式转换很容易出现各种想想不到的问题,所以建议代码做严格的类型查询。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
与mybatis没有关系,是MySQL的隐式类型转换问题
下面来分析一下隐式转换的规则:
两个参数至少有一个是 NULL 时,比较的结果也是 NULL,例外是使用 <=> 对两个 NULL 做比较时会返回 1,这两种情况都不需要做类型转换
两个参数都是字符串,会按照字符串来比较,不做类型转换
两个参数都是整数,按照整数来比较,不做类型转换
十六进制的值和非数字做比较时,会被当做二进制串
有一个参数是 TIMESTAMP 或 DATETIME,并且另外一个参数是常量,常量会被转换为 timestamp
有一个参数是 decimal 类型,如果另外一个参数是 decimal 或者整数,会将整数转换为 decimal 后进行比较,如果另外一个参数是浮点数,则会把 decimal 转换为浮点数进行比较
所有其他情况下,两个参数都会被转换为浮点数再进行比较
与题主相关的只有最后一条:
问题可以简单归纳像如下的情况:
等价于:
id是int类型,参数是字符类型,不同类型比较的过程中,会发生上述的mysql隐式类型转换,两个参数都会被转换为浮点数再进行比较。
'123-1'转换成浮点类型是:
我们看到'123-1'和123转换成浮点型后数值上是相等的,所以
由于 MySQL 隐式类型转换规则比较复杂,依赖 MySQL 隐式转换很容易出现各种想想不到的问题,所以建议代码做严格的类型查询。