Can someone explain me why with that query:
SELECT * FROM `tags` WHERE (tag IN ('willa-lentza', 2016))
it return me all rows from tags
table, but when I put 2016
into quotes it works good ?
tag
column is varchar
type.
SAMPLE ENVIRONMENT
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');
I also get the same error as Roland Bouman got:
Truncated incorrect DOUBLE value: 'willa-lentza'
I cannot reproduce this behaviour, but it seems that your
varchars
get casted into aDOUBLEs
and not the other way around.In this case, the query turns into this:
which is always true for all non-numeric tags.
Could you please run
EXPLAIN EXTENDED SELECT ...
on this statement and post the warning here?To confirm this behavior, you can add another numerical tag:
This tag should be returned by neither of the queries.
To avoid this, just always enclose your constants into single quotes so that they are parsed as
CHARs
Interesting...i got this.
EDIT: actually i think I can exaplain this one. (because 0 is in the in list, mysql thinks the rest og the in list and also the left hand argument 'a' should all be numbers. Casting 'a' will result in 0, so this will intenally be seen as
0 in (0, 0)
but I still can't explain the behavior of the OP
My brief testing does not confirm this behavior.
Not just any string should be able to match an integer. Are you sure you haven't changed anything else?
http://dev.mysql.com/doc/refman/5.0/en/comparison-operators.html#function_in