有人可以用这个查询解释我为什么:
SELECT * FROM `tags` WHERE (tag IN ('willa-lentza', 2016))
它从表中返回所有行tags
,但是当我放入2016
引号时效果很好?
tag
列是varchar
类型。
示例环境
CREATE TABLE `tags` (
`id` int(10) unsigned NOT NULL auto_increment,
`tag` varchar(255) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
INSERT INTO `tags` (`id`, `tag`) VALUES
(1, '2016'),
(2, 'plum'),
(3, 'banana'),
(4, 'apple'),
(5, 'willa-lentza');
我也得到与 Roland Bouman 相同的错误:
Truncated incorrect DOUBLE value: 'willa-lentza'