当使用长类型数来过滤varchar类型时,MySQL返回额外的记录

时间:2018-03-16 14:28:09

标签: mysql precision varchar bigint

一个简单的表格:

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';

我认为查询中的数字类型和长度是原因,但我不知道确切的。

任何评论都将不胜感激。

2 个答案:

答案 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

问候