mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	away. Additional fix for bug#22331. Now Item_field prints its value in the case of the const field. mysql-test/r/varbinary.result: Corrected test case after fix for bug#22331. mysql-test/r/union.result: Corrected test case after fix for bug#22331. mysql-test/r/subselect.result: Corrected test case after fix for bug#22331. mysql-test/r/func_test.result: Corrected test case after fix for bug#22331. mysql-test/r/having.result: Corrected test case after fix for bug#22331. mysql-test/r/func_regexp.result: Corrected test case after fix for bug#22331. mysql-test/r/func_str.result: Corrected test case after fix for bug#22331. mysql-test/r/func_default.result: Corrected test case after fix for bug#22331. mysql-test/r/explain.result: Corrected test case after fix for bug#22331. sql/sql_union.cc: Bug#22331: Wrong WHERE in EXPLAIN EXTENDED when all expressions were optimized away. Cleanup of the SELECT_LEX::order_list list. sql/item.h: Bug#22331: Wrong WHERE in EXPLAIN EXTENDED when all expressions were optimized away. Added the print() member function to the Item_field class. sql/item.cc: Bug#22331: Wrong WHERE in EXPLAIN EXTENDED when all expressions were optimized away. Added the print() member function to the Item_field class.
		
			
				
	
	
		
			90 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| drop table if exists t1;
 | ||
| create table t1 (id int not null, str char(10), unique(str));
 | ||
| explain select * from t1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	system	NULL	NULL	NULL	NULL	0	const row not found
 | ||
| insert into t1 values (1, null),(2, null),(3, "foo"),(4, "bar");
 | ||
| select * from t1 where str is null;
 | ||
| id	str
 | ||
| 1	NULL
 | ||
| 2	NULL
 | ||
| select * from t1 where str="foo";
 | ||
| id	str
 | ||
| 3	foo
 | ||
| explain select * from t1 where str is null;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	str	str	11	const	1	Using where
 | ||
| explain select * from t1 where str="foo";
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	const	str	str	11	const	1	
 | ||
| explain select * from t1 ignore key (str) where str="foo";
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ALL	NULL	NULL	NULL	NULL	4	Using where
 | ||
| explain select * from t1 use key (str,str) where str="foo";
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	const	str	str	11	const	1	
 | ||
| explain select * from t1 use key (str,str,foo) where str="foo";
 | ||
| ERROR HY000: Key 'foo' doesn't exist in table 't1'
 | ||
| explain select * from t1 ignore key (str,str,foo) where str="foo";
 | ||
| ERROR HY000: Key 'foo' doesn't exist in table 't1'
 | ||
| drop table t1;
 | ||
| explain select 1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	No tables used
 | ||
| create table t1 (a int not null);
 | ||
| explain select count(*) from t1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	Select tables optimized away
 | ||
| insert into t1 values(1);
 | ||
| explain select count(*) from t1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	Select tables optimized away
 | ||
| insert into t1 values(1);
 | ||
| explain select count(*) from t1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	Select tables optimized away
 | ||
| drop table t1;
 | ||
| set names koi8r;
 | ||
| create table <20><><EFBFBD> (<28><><EFBFBD>0 int, <20><><EFBFBD>1 int, key <20><><EFBFBD>0 (<28><><EFBFBD>0), key <20><><EFBFBD>01 (<28><><EFBFBD>0,<2C><><EFBFBD>1));
 | ||
| insert into <20><><EFBFBD> (<28><><EFBFBD>0) values (1);
 | ||
| insert into <20><><EFBFBD> (<28><><EFBFBD>0) values (2);
 | ||
| explain select <20><><EFBFBD>0 from <20><><EFBFBD> where <20><><EFBFBD>0=1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	<09><><EFBFBD>	ref	<09><><EFBFBD>0,<2C><><EFBFBD>01	<09><><EFBFBD>0	5	const	1	Using where; Using index
 | ||
| drop table <20><><EFBFBD>;
 | ||
| set names latin1;
 | ||
| select 3 into @v1;
 | ||
| explain select 3 into @v1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	No tables used
 | ||
| create table t1(f1 int, f2 int);
 | ||
| insert into t1 values (1,1);
 | ||
| create view v1 as select * from t1 where f1=1;
 | ||
| explain extended select * from v1 where f2=1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	system	NULL	NULL	NULL	NULL	1	
 | ||
| Warnings:
 | ||
| Note	1003	select '1' AS `f1`,'1' AS `f2` from `test`.`t1` where 1
 | ||
| explain extended select * from t1 where 0;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	Impossible WHERE
 | ||
| Warnings:
 | ||
| Note	1003	select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` where 0
 | ||
| explain extended select * from t1 where 1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	system	NULL	NULL	NULL	NULL	1	
 | ||
| Warnings:
 | ||
| Note	1003	select '1' AS `f1`,'1' AS `f2` from `test`.`t1` where 1
 | ||
| explain extended select * from t1 having 0;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	Impossible HAVING
 | ||
| Warnings:
 | ||
| Note	1003	select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` having 0
 | ||
| explain extended select * from t1 having 1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	system	NULL	NULL	NULL	NULL	1	
 | ||
| Warnings:
 | ||
| Note	1003	select '1' AS `f1`,'1' AS `f2` from `test`.`t1` having 1
 | ||
| drop view v1;
 | ||
| drop table t1;
 |