6

给定表格:

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

为什么,哦,为什么!此查询是否返回结果:

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.

任何解释此行为的文章或文档将不胜感激。

4

1 回答 1

10

它在 MySQL 文档中:http: //dev.mysql.com/doc/refman/5.1/en/type-conversion.html

于 2012-06-13T18:19:48.187 回答