mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	adding test case. item_cmpfunc.cc: Bug#12611 ESCAPE + LIKE do not work when the escape char is a multibyte one Additional fix for 8bit character sets: escape character must be converted into operation character set. sql/item_cmpfunc.cc: Bug#12611 ESCAPE + LIKE do not work when the escape char is a multibyte one Additional fix for 8bit character sets: escape character must be converted into operation character set. mysql-test/t/func_like.test: adding test case. mysql-test/r/func_like.result: adding test case.
		
			
				
	
	
		
			168 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| drop table if exists t1;
 | |
| create table t1 (a varchar(10), key(a));
 | |
| insert into t1 values ("a"),("abc"),("abcd"),("hello"),("test");
 | |
| explain select * from t1 where a like 'abc%';
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	t1	range	a	a	11	NULL	1	Using where; Using index
 | |
| explain select * from t1 where a like concat('abc','%');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	t1	range	a	a	11	NULL	1	Using where; Using index
 | |
| 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
 |