mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			110 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
# General purpose bug fix tests go here : subselect.test too large
 | 
						|
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Bug #46791: Assertion failed:(table->key_read==0),function unknown
 | 
						|
--echo #    function,file sql_base.cc
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (a INT, b INT, KEY(a));
 | 
						|
INSERT INTO t1 VALUES (1,1),(2,2);
 | 
						|
CREATE TABLE t2 LIKE t1;
 | 
						|
INSERT INTO t2 VALUES (1,1),(2,2);
 | 
						|
CREATE TABLE t3 LIKE t1;
 | 
						|
 | 
						|
--echo # should have 1 impossible where and 2 dependent subqueries
 | 
						|
EXPLAIN
 | 
						|
SELECT 1 FROM t1
 | 
						|
WHERE NOT EXISTS (SELECT 1 FROM t2 WHERE 1 = (SELECT MIN(t2.b) FROM t3))
 | 
						|
ORDER BY count(*);
 | 
						|
 | 
						|
--echo # should not crash the next statement
 | 
						|
SELECT 1 FROM t1
 | 
						|
WHERE NOT EXISTS (SELECT 1 FROM t2 WHERE 1 = (SELECT MIN(t2.b) FROM t3))
 | 
						|
ORDER BY count(*);
 | 
						|
 | 
						|
--echo # should not crash: the crash is caused by the previous statement
 | 
						|
SELECT 1;
 | 
						|
 | 
						|
DROP TABLE t1,t2,t3;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Bug #47106: Crash / segfault on adding EXPLAIN to a non-crashing 
 | 
						|
--echo # query
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (
 | 
						|
  a INT,
 | 
						|
  b INT,
 | 
						|
  PRIMARY KEY (a),
 | 
						|
  KEY b (b)
 | 
						|
);
 | 
						|
INSERT INTO t1 VALUES (1, 1), (2, 1);
 | 
						|
 | 
						|
CREATE TABLE t2 LIKE t1;
 | 
						|
INSERT INTO t2 SELECT * FROM t1;
 | 
						|
 | 
						|
CREATE TABLE t3 LIKE t1;
 | 
						|
INSERT INTO t3 SELECT * FROM t1;
 | 
						|
 | 
						|
--echo # Should not crash.
 | 
						|
--echo # Should have 1 impossible where and 2 dependent subqs.
 | 
						|
EXPLAIN
 | 
						|
SELECT
 | 
						|
  (SELECT 1 FROM t1,t2 WHERE t2.b > t3.b)
 | 
						|
FROM t3 WHERE 1 = 0 GROUP BY 1;
 | 
						|
 | 
						|
--echo # should return 0 rows
 | 
						|
SELECT
 | 
						|
  (SELECT 1 FROM t1,t2 WHERE t2.b > t3.b)
 | 
						|
FROM t3 WHERE 1 = 0 GROUP BY 1;
 | 
						|
 | 
						|
DROP TABLE t1,t2,t3;
 | 
						|
 | 
						|
--echo End of 5.0 tests.
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Bug#54568: create view cause Assertion failed: 0, 
 | 
						|
--echo # file .\item_subselect.cc, line 836
 | 
						|
--echo #
 | 
						|
EXPLAIN SELECT 1 LIKE ( 1 IN ( SELECT 1 ) );
 | 
						|
DESCRIBE SELECT 1 LIKE ( 1 IN ( SELECT 1 ) );
 | 
						|
--echo # None of the below should crash
 | 
						|
CREATE VIEW v1 AS SELECT 1 LIKE ( 1 IN ( SELECT 1 ) );
 | 
						|
CREATE VIEW v2 AS SELECT 1 LIKE '%' ESCAPE ( 1 IN ( SELECT 1 ) );
 | 
						|
DROP VIEW v1, v2;
 | 
						|
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # End of 5.1 tests.
 | 
						|
--echo #
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Bug#53236 Segfault in DTCollation::set(DTCollation&)
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (
 | 
						|
  pk INTEGER AUTO_INCREMENT,
 | 
						|
  col_varchar VARCHAR(1),
 | 
						|
  PRIMARY KEY (pk)
 | 
						|
)
 | 
						|
;
 | 
						|
 | 
						|
INSERT INTO t1 (col_varchar) 
 | 
						|
VALUES
 | 
						|
('w'),
 | 
						|
('m')
 | 
						|
;
 | 
						|
 | 
						|
SELECT  table1.pk
 | 
						|
FROM ( t1 AS table1 JOIN t1 AS table2 ON (table1.col_varchar =
 | 
						|
                                          table2.col_varchar) ) 
 | 
						|
WHERE ( 1, 2 ) IN ( SELECT SUBQUERY1_t1.pk AS SUBQUERY1_field1,
 | 
						|
                           SUBQUERY1_t1.pk AS SUBQUERY1_field2
 | 
						|
                    FROM ( t1 AS SUBQUERY1_t1 JOIN t1 AS SUBQUERY1_t2
 | 
						|
                           ON (SUBQUERY1_t2.col_varchar =
 | 
						|
                               SUBQUERY1_t1.col_varchar) ) ) 
 | 
						|
;
 | 
						|
 | 
						|
drop table t1;
 |