一个简单的表格:
CREATE TABLE `tbl_type_test` (
`uid` varchar(31) NOT NULL DEFAULT '0',
`value` varchar(15) NOT NULL DEFAULT '',
PRIMARY KEY (`uid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
和一些记录:
'6011656821812318924', 'a'
'6011656821812318925', 'b'
'6011656821812318926', 'c'
当我执行以下SQL时,将返回3条记录
select * from tbl_type_test where uid = 6011656821812318924;
这也会返回 3 条记录。诡异的。
select * from tbl_type_test where uid = 6011656821812318900;
如果我将数字更改为字符串类型,如预期的那样,只会返回 1 条记录:
select * from tbl_type_test where uid = '6011656821812318924';
我认为查询中的数字类型和长度是原因,但我不知道确切的原因。
任何评论将不胜感激。
在所有其他情况下,参数将作为浮点数(实数)进行比较。 - https://dev.mysql.com/doc/refman/5.7/en/type-conversion.html https://dev.mysql.com/doc/refman/5.7/en/type-conversion.html
例如
drop procedure if exists p;
delimiter $$
create procedure p (inval float, inval2 float, inval3 float)
select inval,inval2,inval3;
call p(6011656821812318924,6011656821812318925,6011656821812318926);
+------------+------------+------------+
| inval | inval2 | inval3 |
+------------+------------+------------+
| 6.01166e18 | 6.01166e18 | 6.01166e18 |
+------------+------------+------------+
1 row in set (0.00 sec)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)