mirror of
https://github.com/MariaDB/server.git
synced 2025-08-24 11:21:36 +02:00

Some queries of the test case used to execute too fast, which caused `opt_hint_timeout` test failures. This commit replaces those queries with more complex ones to make sure they cannot be executed in a couple of milliseconds.
106 lines
3.5 KiB
Text
106 lines
3.5 KiB
Text
# Setting statement time-outs is not possible for the embedded server neither
|
|
# by SET STATEMENT max_statement_time=X nor by /*+ MAX_EXECUTION_TIME(X)*/ hint.
|
|
# That is why this test is disabled for the embedded server
|
|
--source include/not_embedded.inc
|
|
|
|
--disable_view_protocol # Since optimizer hints are not supported inside views
|
|
|
|
--source include/have_sequence.inc
|
|
--echo #
|
|
--echo # MAX_EXECUTION_TIME hint testing
|
|
--echo #
|
|
--enable_prepare_warnings
|
|
|
|
CREATE TABLE t1 (a INT);
|
|
|
|
INSERT INTO t1 SELECT seq FROM seq_1_to_5000;
|
|
|
|
-- disable_query_log
|
|
-- disable_result_log
|
|
analyze table t1;
|
|
-- enable_result_log
|
|
-- enable_query_log
|
|
|
|
--echo # Correct hint usage
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SELECT /*+ MAX_EXECUTION_TIME(10) */* FROM t1 a, t1 b;
|
|
|
|
EXPLAIN EXTENDED SELECT /*+ MAX_EXECUTION_TIME(0001490) */* FROM t1;
|
|
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SELECT /*+ MAX_EXECUTION_TIME(20) */ *, SLEEP(1) FROM t1 UNION SELECT 1, 2;
|
|
--error ER_STATEMENT_TIMEOUT
|
|
(SELECT /*+ MAX_EXECUTION_TIME(300) */ *, SLEEP(1) FROM t1) UNION (SELECT 1, 2);
|
|
--error ER_STATEMENT_TIMEOUT
|
|
((SELECT /*+ MAX_EXECUTION_TIME(500) */ *, SLEEP(1) FROM t1));
|
|
|
|
--echo # Make sure the hint overrides global/session/statement settings.
|
|
--echo # Global setting 30 seconds, won't be exceeded for sure
|
|
SET @@max_statement_time = 30;
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SELECT /*+ MAX_EXECUTION_TIME(10)*/ count(*) FROM t1 a natural join t1 b natural join t1 c;
|
|
|
|
--echo # Session setting 30 seconds, too long to be exceeded
|
|
SET SESSION max_statement_time = 30;
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SELECT /*+ MAX_EXECUTION_TIME(15) */ count(*) FROM t1 a natural join t1 b natural join t1 c;
|
|
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SET STATEMENT max_statement_time = 20 FOR
|
|
SELECT /*+ MAX_EXECUTION_TIME(5)*/ count(*) FROM t1 a natural join t1 b natural join t1 c;
|
|
|
|
--echo # Check that prepared statements process the hint correctly
|
|
PREPARE s FROM 'SELECT /*+ MAX_EXECUTION_TIME(20) */ seq, SLEEP(1) FROM seq_1_to_10';
|
|
--error ER_STATEMENT_TIMEOUT
|
|
EXECUTE s;
|
|
--error ER_STATEMENT_TIMEOUT
|
|
EXECUTE s;
|
|
|
|
--echo # Hint duplication
|
|
SELECT /*+ MAX_EXECUTION_TIME(50000) MAX_EXECUTION_TIME(100) */ count(*) FROM t1;
|
|
|
|
--echo # Wrong values
|
|
SELECT /*+ MAX_EXECUTION_TIME(0) */ count(*) FROM t1;
|
|
SELECT /*+ MAX_EXECUTION_TIME(-1) */ count(*) FROM t1;
|
|
SELECT /*+ MAX_EXECUTION_TIME(4294967296) */ count(*) FROM t1;
|
|
|
|
--echo
|
|
--echo # only SELECT statements support the MAX_EXECUTION_TIME hint (warning):
|
|
--echo
|
|
CREATE TABLE t2 (i INT);
|
|
INSERT /*+ MAX_EXECUTION_TIME(10) */ INTO t2 SELECT 1;
|
|
INSERT INTO t2 SELECT /*+ MAX_EXECUTION_TIME(10) */ 1;
|
|
REPLACE /*+ MAX_EXECUTION_TIME(15) */ INTO t2 SELECT 1;
|
|
REPLACE INTO t2 SELECT /*+ MAX_EXECUTION_TIME(10) */ 1;
|
|
UPDATE /*+ MAX_EXECUTION_TIME(23) */ t2 SET i = 1;
|
|
DELETE /*+ MAX_EXECUTION_TIME(5000) */ FROM t2 WHERE i = 1;
|
|
|
|
--echo # Not supported inside stored procedures/functions
|
|
DELIMITER |;
|
|
CREATE PROCEDURE p1() BEGIN SELECT /*+ MAX_EXECUTION_TIME(10) */ count(*) FROM t1 a, t1 b
|
|
INTO @a; END|
|
|
DELIMITER ;|
|
|
|
|
CALL p1();
|
|
DROP PROCEDURE p1;
|
|
|
|
--echo # Hint in a subquery is not allowed (warning):
|
|
SELECT 1 FROM (SELECT /*+ MAX_EXECUTION_TIME(10) */ 1) a;
|
|
|
|
--echo # Hint is allowed only for the first select of UNION (warning):
|
|
SELECT /*+ MAX_EXECUTION_TIME(50000) */ count(*) FROM t1
|
|
UNION
|
|
SELECT /*+ MAX_EXECUTION_TIME(3) */ count(*) FROM t1;
|
|
|
|
SELECT count(*) FROM t1
|
|
UNION
|
|
SELECT /*+ MAX_EXECUTION_TIME(30) */ count(*) FROM t1;
|
|
|
|
--echo # Check that hint actually works:
|
|
--error ER_STATEMENT_TIMEOUT
|
|
SELECT /*+ MAX_EXECUTION_TIME(20) */ count(*), SLEEP(1) FROM t1
|
|
UNION
|
|
SELECT count(*), SLEEP(1) FROM t1;
|
|
|
|
DROP TABLE t1, t2;
|
|
|