一个简单的表格:
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';
我认为查询中的数字类型和长度是原因,但我不知道确切的。
任何评论都将不胜感激。
答案 0 :(得分:1)
在所有其他情况下,将参数作为浮点(实数)进行比较。 - 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)
答案 1 :(得分:0)
默认情况下,MySQL将1和'1'视为相同,但您可以通过将MySQL行为设置为严格模式来更改它。
设置@@ GLOBAL.sql_mode =“STRICT_ALL_TABLES”; 设置@@ SESSION.sql_mode =“STRICT_ALL_TABLES”;
或者您可以在my.cnf文件中将这些变量设置为sql_mode =''中的永久变量。这样,如果使用了错误的类型,MySQL将抛出错误。读 https://dev.mysql.com/doc/refman/5.7/en/constraint-invalid-data.html
问候