mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
a2850a2f53
Problem: when processing a query like: SELECT '' LIKE '1' ESCAPE COUNT(1); escape_item->val_str() was never executed and the "escape" class member stayed initialized, which led to valgrind uninitialized memory error. Note, a query with some tables in "FROM" clause returns ER_WRONG_ARGUMENTS in the same situation: SELECT '' LIKE '1' ESCAPE COUNT(1) FROM t1; ERROR 1210 (HY000): Incorrect arguments to ESCAPE Fix: disallowing using aggregate functions in ESCAPE clause, even if there are no tables used. There is no much use of that anyway.
190 lines
4.4 KiB
Text
190 lines
4.4 KiB
Text
drop table if exists t1;
|
|
create table t1 (a varchar(10), key(a));
|
|
insert into t1 values ("a"),("abc"),("abcd"),("hello"),("test");
|
|
explain extended select * from t1 where a like 'abc%';
|
|
id select_type table type possible_keys key key_len ref rows filtered Extra
|
|
1 SIMPLE t1 index a a 13 NULL 5 20.00 Using where; Using index
|
|
Warnings:
|
|
Note 1003 select `test`.`t1`.`a` AS `a` from `test`.`t1` where (`test`.`t1`.`a` like 'abc%')
|
|
explain extended select * from t1 where a like concat('abc','%');
|
|
id select_type table type possible_keys key key_len ref rows filtered Extra
|
|
1 SIMPLE t1 index a a 13 NULL 5 20.00 Using where; Using index
|
|
Warnings:
|
|
Note 1003 select `test`.`t1`.`a` AS `a` from `test`.`t1` where (`test`.`t1`.`a` like concat('abc','%'))
|
|
select * from t1 where a like "abc%";
|
|
a
|
|
abc
|
|
abcd
|
|
select * from t1 where a like concat("abc","%");
|
|
a
|
|
abc
|
|
abcd
|
|
select * from t1 where a like "ABC%";
|
|
a
|
|
abc
|
|
abcd
|
|
select * from t1 where a like "test%";
|
|
a
|
|
test
|
|
select * from t1 where a like "te_t";
|
|
a
|
|
test
|
|
select * from t1 where a like "%a%";
|
|
a
|
|
a
|
|
abc
|
|
abcd
|
|
select * from t1 where a like "%abcd%";
|
|
a
|
|
abcd
|
|
select * from t1 where a like "%abc\d%";
|
|
a
|
|
abcd
|
|
drop table t1;
|
|
create table t1 (a varchar(10), key(a));
|
|
insert into t1 values ('a'), ('a\\b');
|
|
select * from t1 where a like 'a\\%' escape '#';
|
|
a
|
|
a\b
|
|
select * from t1 where a like 'a\\%' escape '#' and a like 'a\\\\b';
|
|
a
|
|
a\b
|
|
prepare stmt1 from 'select * from t1 where a like \'a\\%\' escape ?';
|
|
set @esc='#';
|
|
execute stmt1 using @esc;
|
|
a
|
|
a\b
|
|
deallocate prepare stmt1;
|
|
drop table t1;
|
|
create table t1 (a datetime);
|
|
insert into t1 values ('2004-03-11 12:00:21');
|
|
select * from t1 where a like '2004-03-11 12:00:21';
|
|
a
|
|
2004-03-11 12:00:21
|
|
drop table t1;
|
|
SET NAMES koi8r;
|
|
CREATE TABLE t1 (a VARCHAR(10) CHARACTER SET koi8r);
|
|
INSERT INTO t1 VALUES ('ÆÙ×Á'),('æÙ×Á'),('Æù×Á'),('ÆÙ÷Á'),('ÆÙ×á'),('æù÷á');
|
|
INSERT INTO t1 VALUES ('ÆÙ×ÁÐÒÏÌÄÖ'),('æÙ×ÁÐÒÏÌÄÖ'),('Æù×ÁÐÒÏÌÄÖ'),('ÆÙ÷ÁÐÒÏÌÄÖ');
|
|
INSERT INTO t1 VALUES ('ÆÙ×áÐÒÏÌÄÖ'),('ÆÙ×ÁðÒÏÌÄÖ'),('ÆÙ×ÁÐòÏÌÄÖ'),('ÆÙ×ÁÐÒïÌÄÖ');
|
|
INSERT INTO t1 VALUES ('ÆÙ×ÁÐÒÏìÄÖ'),('ÆÙ×ÁÐÒÏÌäÖ'),('ÆÙ×ÁÐÒÏÌÄö'),('æù÷áðòïìäö');
|
|
SELECT * FROM t1 WHERE a LIKE '%Æù×Á%';
|
|
a
|
|
ÆÙ×Á
|
|
æÙ×Á
|
|
Æù×Á
|
|
ÆÙ÷Á
|
|
ÆÙ×á
|
|
æù÷á
|
|
ÆÙ×ÁÐÒÏÌÄÖ
|
|
æÙ×ÁÐÒÏÌÄÖ
|
|
Æù×ÁÐÒÏÌÄÖ
|
|
ÆÙ÷ÁÐÒÏÌÄÖ
|
|
ÆÙ×áÐÒÏÌÄÖ
|
|
ÆÙ×ÁðÒÏÌÄÖ
|
|
ÆÙ×ÁÐòÏÌÄÖ
|
|
ÆÙ×ÁÐÒïÌÄÖ
|
|
ÆÙ×ÁÐÒÏìÄÖ
|
|
ÆÙ×ÁÐÒÏÌäÖ
|
|
ÆÙ×ÁÐÒÏÌÄö
|
|
æù÷áðòïìäö
|
|
SELECT * FROM t1 WHERE a LIKE '%Æù×%';
|
|
a
|
|
ÆÙ×Á
|
|
æÙ×Á
|
|
Æù×Á
|
|
ÆÙ÷Á
|
|
ÆÙ×á
|
|
æù÷á
|
|
ÆÙ×ÁÐÒÏÌÄÖ
|
|
æÙ×ÁÐÒÏÌÄÖ
|
|
Æù×ÁÐÒÏÌÄÖ
|
|
ÆÙ÷ÁÐÒÏÌÄÖ
|
|
ÆÙ×áÐÒÏÌÄÖ
|
|
ÆÙ×ÁðÒÏÌÄÖ
|
|
ÆÙ×ÁÐòÏÌÄÖ
|
|
ÆÙ×ÁÐÒïÌÄÖ
|
|
ÆÙ×ÁÐÒÏìÄÖ
|
|
ÆÙ×ÁÐÒÏÌäÖ
|
|
ÆÙ×ÁÐÒÏÌÄö
|
|
æù÷áðòïìäö
|
|
SELECT * FROM t1 WHERE a LIKE 'Æù×Á%';
|
|
a
|
|
ÆÙ×Á
|
|
æÙ×Á
|
|
Æù×Á
|
|
ÆÙ÷Á
|
|
ÆÙ×á
|
|
æù÷á
|
|
ÆÙ×ÁÐÒÏÌÄÖ
|
|
æÙ×ÁÐÒÏÌÄÖ
|
|
Æù×ÁÐÒÏÌÄÖ
|
|
ÆÙ÷ÁÐÒÏÌÄÖ
|
|
ÆÙ×áÐÒÏÌÄÖ
|
|
ÆÙ×ÁðÒÏÌÄÖ
|
|
ÆÙ×ÁÐòÏÌÄÖ
|
|
ÆÙ×ÁÐÒïÌÄÖ
|
|
ÆÙ×ÁÐÒÏìÄÖ
|
|
ÆÙ×ÁÐÒÏÌäÖ
|
|
ÆÙ×ÁÐÒÏÌÄö
|
|
æù÷áðòïìäö
|
|
DROP TABLE t1;
|
|
SET NAMES cp1250;
|
|
CREATE TABLE t1 (a varchar(250) NOT NULL) DEFAULT CHARACTER SET=cp1250;
|
|
INSERT INTO t1 VALUES
|
|
('Techni Tapes Sp. z o.o.'),
|
|
('Pojazdy Szynowe PESA Bydgoszcz SA Holding'),
|
|
('AKAPESTER 1 P.P.H.U.'),
|
|
('Pojazdy Szynowe PESA Bydgoszcz S A Holding'),
|
|
('PPUH PESKA-I Maria Struniarska');
|
|
select * from t1 where a like '%PESA%';
|
|
a
|
|
Pojazdy Szynowe PESA Bydgoszcz SA Holding
|
|
Pojazdy Szynowe PESA Bydgoszcz S A Holding
|
|
select * from t1 where a like '%PESA %';
|
|
a
|
|
Pojazdy Szynowe PESA Bydgoszcz SA Holding
|
|
Pojazdy Szynowe PESA Bydgoszcz S A Holding
|
|
select * from t1 where a like '%PES%';
|
|
a
|
|
Techni Tapes Sp. z o.o.
|
|
Pojazdy Szynowe PESA Bydgoszcz SA Holding
|
|
AKAPESTER 1 P.P.H.U.
|
|
Pojazdy Szynowe PESA Bydgoszcz S A Holding
|
|
PPUH PESKA-I Maria Struniarska
|
|
select * from t1 where a like '%PESKA%';
|
|
a
|
|
PPUH PESKA-I Maria Struniarska
|
|
select * from t1 where a like '%ESKA%';
|
|
a
|
|
PPUH PESKA-I Maria Struniarska
|
|
DROP TABLE t1;
|
|
select _cp866'aaaaaaaaa' like _cp866'%aaaa%' collate cp866_bin;
|
|
_cp866'aaaaaaaaa' like _cp866'%aaaa%' collate cp866_bin
|
|
1
|
|
set names koi8r;
|
|
select 'andre%' like 'andreÊ%' escape 'Ê';
|
|
'andre%' like 'andreÊ%' escape 'Ê'
|
|
1
|
|
select _cp1251'andre%' like convert('andreÊ%' using cp1251) escape 'Ê';
|
|
_cp1251'andre%' like convert('andreÊ%' using cp1251) escape 'Ê'
|
|
1
|
|
End of 4.1 tests
|
|
#
|
|
# Bug #54575: crash when joining tables with unique set column
|
|
#
|
|
CREATE TABLE t1(a SET('a') NOT NULL, UNIQUE KEY(a));
|
|
CREATE TABLE t2(b INT PRIMARY KEY);
|
|
INSERT INTO t1 VALUES ();
|
|
Warnings:
|
|
Warning 1364 Field 'a' doesn't have a default value
|
|
INSERT INTO t2 VALUES (1), (2), (3);
|
|
SELECT 1 FROM t2 JOIN t1 ON 1 LIKE a GROUP BY a;
|
|
1
|
|
DROP TABLE t1, t2;
|
|
#
|
|
# Bug#59149 valgrind warnings with "like .. escape .." function
|
|
#
|
|
SELECT '' LIKE '1' ESCAPE COUNT(1);
|
|
ERROR HY000: Incorrect arguments to ESCAPE
|
|
End of 5.1 tests
|