如果MySQL WHERE条件类型和要查询的字段数据类型一致,会对查询结果有什么影响呢?
创建一张表
DROP TABLE if EXISTS t_student;
CREATE TABLE t_student (
`id` BIGINT NOT NULL auto_increment COMMENT '主键',
`name` VARCHAR(20) COMMENT '姓名',
`number` VARCHAR(10) COMMENT '学号',
primary key(`id`)
) ENGINE=INNODB DEFAULT charset=utf8 COMMENT '学生表';
表里插入数据
INSERT INTO t_student VALUES (NULL, 'lilei', '1');
INSERT INTO t_student VALUES (NULL, 'hanmeimei', '2');
INSERT INTO t_student VALUES (NULL, 'jim', '2');
查询
SELECT * FROM t_student

一:查询数据(类型一致)
SELECT * FROM t_student WHERE number = '1';

WHERE条件字段数据类型和要查询字段的实际数据类型一致,结果是没有问题的。
二:查询数据(类型不一致)
SELECT * FROM t_student WHERE number = 1;

WHERE条件是Int类型,MySQL会把number列的数据(VARCHAR)转成Int类型,然后再和条件匹配,此时匹配到一条数据。
SELECT * FROM t_student WHERE number = 2;

同理:WHERE条件是Int类型,MySQL会把number列的数据转成Int类型,然后和条件匹配,此时匹配到一条数据。
SELECT * FROM t_student WHERE number = 0;

WHERE条件是Int类型,MySQL会把number列的数据转成Int类型,然后匹配。number列类型是字符串,非数字字符串转成Int类型,会转成0,此时匹配到一条数据。
网友评论