Есть ли простой запрос, который занял бы> 2 секунды, чтобы я мог проверить медленный регистратор запросов?
Я ищу что-то вроде общего рекурсивного или итеративного утверждения.
Простой запрос будет:
SELECT SLEEP(2);
Вы хотите повторить это?
DELIMITER $$
DROP FUNCTION IF EXISTS `iterateSleep` $$
CREATE FUNCTION `iterateSleep` (iterations INT)
RETURNS INT DETERMINISTIC
BEGIN
DECLARE remainder INT;
SET remainder = iterations;
read_loop: LOOP
IF remainder=0 THEN
LEAVE read_loop;
END IF;
SELECT SLEEP(2) INTO @test;
SET remainder = remainder - 1;
END LOOP;
RETURN iterations;
END $$
DELIMITER ;
-- TO TEST IT OUT
mysql> SELECT iterateSleep(2);
+-----------------+
| iterateSleep(2) |
+-----------------+
| 2 |
+-----------------+
1 row in set (4.01 sec)
В качестве альтернативы, если вы просто хотите протестировать свой slow_query_log, измените long_query_time на 0 (для регистрации всех запросов):
SET long_query_time=0;
WAITFOR DELAY '00:00:02'
SELECT sleep(2)
ничего не добавил к медленному журналу - ноSET GLOBAL long_query_time=0
дал мне быстрый ввод для проверки. Благодарю.Вот довольно ужасный запрос. Это декартово произведение, использующее не-ANSI стиль соединения.
источник