比较字符串与数字字段返回意外结果

时间:2012-06-13 18:17:42

标签: php mysql sql

鉴于表格:

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

任何解释此行为的文章或文档都将受到赞赏。

1 个答案:

答案 0 :(得分:10)

相关问题