鉴于表格:
CREATE TABLE IF NOT EXISTS `users` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`name` varchar(100) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
添加几行:
INSERT INTO `users` (`id`,`name`) VALUES (NULL , 'Bob'),(NULL , 'Larry'),(NULL , 'Steve');
为什么,OH为什么!此查询是否返回结果:
SELECT * FROM `users` WHERE id = "2this-is-not a numeric value"
结果:
query returned 1 row(s) in 0.0003 sec
id name
-----------------
2 Larry
where子句中使用的字符串显然正在转换为数值 - 谁说要这样做?!我找不到任何暗示mysql或PHP会假定自动生成我的字符串文字的文档。
仅当数字字符是字符串中的第一个字符时才有效,"this 2 is not numeric"
不会返回结果。 "12 2"
将成为12
,"1 2"
(one-space-two)将变为1
。
任何解释此行为的文章或文档都将受到赞赏。