mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
71fe190172
The fix for bug 31887 was incomplete : it assumes that all the field types returned by the IS_NUM macro are descendants of Item_num and tries to zero-fill the values before doing constant substitution with such fields when they are compared to constant string values. The only exception to this is Field_timestamp : it's in the IS_NUM macro, but is not a descendant of Field_num. Fixed by excluding timestamp fields (Field_timestamp) when zero-filling when converting the constant to compare with to a string. Note that this will not exclude the timestamp columns from const propagation. mysql-test/r/compare.result: Bug #39353: test case mysql-test/t/compare.test: Bug #39353: test case sql/item.cc: Bug #39353: don't zero-fill timestamp fields when const propagating to a string : they'll be converted to a string in a date/time format and not as an integer.
98 lines
3 KiB
Text
98 lines
3 KiB
Text
drop table if exists t1;
|
||
CREATE TABLE t1 (id CHAR(12) not null, PRIMARY KEY (id));
|
||
insert into t1 values ('000000000001'),('000000000002');
|
||
explain select * from t1 where id=000000000001;
|
||
id select_type table type possible_keys key key_len ref rows Extra
|
||
1 SIMPLE t1 index PRIMARY PRIMARY 12 NULL 2 Using where; Using index
|
||
select * from t1 where id=000000000001;
|
||
id
|
||
000000000001
|
||
delete from t1 where id=000000000002;
|
||
select * from t1;
|
||
id
|
||
000000000001
|
||
drop table t1;
|
||
SELECT 'a' = 'a ';
|
||
'a' = 'a '
|
||
1
|
||
SELECT 'a\0' < 'a';
|
||
'a\0' < 'a'
|
||
1
|
||
SELECT 'a\0' < 'a ';
|
||
'a\0' < 'a '
|
||
1
|
||
SELECT 'a\t' < 'a';
|
||
'a\t' < 'a'
|
||
1
|
||
SELECT 'a\t' < 'a ';
|
||
'a\t' < 'a '
|
||
1
|
||
CREATE TABLE t1 (a char(10) not null);
|
||
INSERT INTO t1 VALUES ('a'),('a\0'),('a\t'),('a ');
|
||
SELECT hex(a),STRCMP(a,'a'), STRCMP(a,'a ') FROM t1;
|
||
hex(a) STRCMP(a,'a') STRCMP(a,'a ')
|
||
61 0 0
|
||
6100 -1 -1
|
||
6109 -1 -1
|
||
61 0 0
|
||
DROP TABLE t1;
|
||
SELECT CHAR(31) = '', '' = CHAR(31);
|
||
CHAR(31) = '' '' = CHAR(31)
|
||
0 0
|
||
SELECT CHAR(30) = '', '' = CHAR(30);
|
||
CHAR(30) = '' '' = CHAR(30)
|
||
0 0
|
||
create table t1 (a tinyint(1),b binary(1));
|
||
insert into t1 values (0x01,0x01);
|
||
select * from t1 where a=b;
|
||
a b
|
||
Warnings:
|
||
Warning 1292 Truncated incorrect DOUBLE value: ''
|
||
select * from t1 where a=b and b=0x01;
|
||
a b
|
||
Warnings:
|
||
Warning 1292 Truncated incorrect DOUBLE value: ''
|
||
drop table if exists t1;
|
||
CREATE TABLE t1 (b int(2) zerofill, c int(2) zerofill);
|
||
INSERT INTO t1 (b,c) VALUES (1,2), (1,1), (2,2);
|
||
SELECT CONCAT(b,c), CONCAT(b,c) = '0101' FROM t1;
|
||
CONCAT(b,c) CONCAT(b,c) = '0101'
|
||
0102 0
|
||
0101 1
|
||
0202 0
|
||
EXPLAIN EXTENDED SELECT b,c FROM t1 WHERE b = 1 AND CONCAT(b,c) = '0101';
|
||
id select_type table type possible_keys key key_len ref rows Extra
|
||
1 SIMPLE t1 ALL NULL NULL NULL NULL 3 Using where
|
||
Warnings:
|
||
Note 1003 select `test`.`t1`.`b` AS `b`,`test`.`t1`.`c` AS `c` from `test`.`t1` where ((`test`.`t1`.`b` = 1) and (concat(_binary'01',`test`.`t1`.`c`) = _latin1'0101'))
|
||
SELECT b,c FROM t1 WHERE b = 1 AND CONCAT(b,c) = '0101';
|
||
b c
|
||
01 01
|
||
CREATE TABLE t2 (a int);
|
||
INSERT INTO t2 VALUES (1),(2);
|
||
SELECT a,
|
||
(SELECT COUNT(*) FROM t1
|
||
WHERE b = t2.a AND CONCAT(b,c) = CONCAT('0',t2.a,'01')) x
|
||
FROM t2 ORDER BY a;
|
||
a x
|
||
1 1
|
||
2 0
|
||
EXPLAIN EXTENDED
|
||
SELECT a,
|
||
(SELECT COUNT(*) FROM t1
|
||
WHERE b = t2.a AND CONCAT(b,c) = CONCAT('0',t2.a,'01')) x
|
||
FROM t2 ORDER BY a;
|
||
id select_type table type possible_keys key key_len ref rows Extra
|
||
1 PRIMARY t2 ALL NULL NULL NULL NULL 2 Using filesort
|
||
2 DEPENDENT SUBQUERY t1 ALL NULL NULL NULL NULL 3 Using where
|
||
Warnings:
|
||
Note 1276 Field or reference 'test.t2.a' of SELECT #2 was resolved in SELECT #1
|
||
Note 1276 Field or reference 'test.t2.a' of SELECT #2 was resolved in SELECT #1
|
||
Note 1003 select `test`.`t2`.`a` AS `a`,(select count(0) AS `COUNT(*)` from `test`.`t1` where ((`test`.`t1`.`b` = `test`.`t2`.`a`) and (concat(`test`.`t1`.`b`,`test`.`t1`.`c`) = concat(_latin1'0',`test`.`t2`.`a`,_latin1'01')))) AS `x` from `test`.`t2` order by `test`.`t2`.`a`
|
||
DROP TABLE t1,t2;
|
||
CREATE TABLE t1 (a TIMESTAMP);
|
||
INSERT INTO t1 VALUES (NOW()),(NOW()),(NOW());
|
||
SELECT * FROM t1 WHERE a > '2008-01-01' AND a = '0000-00-00';
|
||
a
|
||
DROP TABLE t1;
|
||
End of 5.0 tests
|