mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 20:36:16 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			261 lines
		
	
	
	
		
			6.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			261 lines
		
	
	
	
		
			6.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
--source include/no_valgrind_without_big.inc
 | 
						|
 | 
						|
#
 | 
						|
# Testing of slow log query options
 | 
						|
#
 | 
						|
 | 
						|
set @@log_slow_verbosity="";
 | 
						|
 | 
						|
select @@log_slow_filter;
 | 
						|
select @@log_slow_rate_limit;
 | 
						|
select @@log_slow_verbosity;
 | 
						|
--replace_regex /\S+mysqld-slow.log/$PATH\/mysqld-slow.log/
 | 
						|
show variables like "log_slow%";
 | 
						|
set @org_slow_query_log= @@global.slow_query_log;
 | 
						|
 | 
						|
# Some simple test to set log_slow_filter
 | 
						|
set @@log_slow_filter= "filesort,filesort_on_disk,full_join,full_scan,query_cache,query_cache_miss,tmp_table,tmp_table_on_disk,admin";
 | 
						|
select @@log_slow_filter;
 | 
						|
set @@log_slow_filter="admin,admin";
 | 
						|
select @@log_slow_filter;
 | 
						|
set @@log_slow_filter=7;
 | 
						|
select @@log_slow_filter;
 | 
						|
 | 
						|
# Test of wrong values
 | 
						|
--error 1231
 | 
						|
set @@log_slow_filter= "filesort,impossible,impossible2,admin";
 | 
						|
--error 1231
 | 
						|
set @@log_slow_filter= "filesort, admin";
 | 
						|
--error 1231
 | 
						|
set @@log_slow_filter= 1<<31;
 | 
						|
select @@log_slow_filter;
 | 
						|
 | 
						|
# Some simple test to set log_slow_verbosity
 | 
						|
set @@log_slow_verbosity= "query_plan,innodb";
 | 
						|
select @@log_slow_verbosity;
 | 
						|
set @@log_slow_verbosity=1;
 | 
						|
select @@log_slow_verbosity;
 | 
						|
 | 
						|
#
 | 
						|
# Check which fields are in slow_log table
 | 
						|
#
 | 
						|
 | 
						|
show fields from mysql.slow_log;
 | 
						|
 | 
						|
#
 | 
						|
# Check flush command
 | 
						|
#
 | 
						|
--disable_cursor_protocol
 | 
						|
--disable_ps2_protocol
 | 
						|
 | 
						|
flush slow logs;
 | 
						|
 | 
						|
# MDEV-4206 (empty filter should be no filter)
 | 
						|
set long_query_time=0.1;
 | 
						|
set log_slow_filter='';
 | 
						|
set slow_query_log=1;
 | 
						|
set global log_output='TABLE';
 | 
						|
select sleep(0.5);
 | 
						|
select count(*) FROM mysql.slow_log;
 | 
						|
 | 
						|
# Reset used variables
 | 
						|
set @@long_query_time=default;
 | 
						|
set @@slow_query_log=default;
 | 
						|
set @@log_slow_filter=default;
 | 
						|
set @@log_slow_verbosity=default;
 | 
						|
set global log_output= default;
 | 
						|
truncate mysql.slow_log;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-18333 Slow_queries count doesn't increase when slow_query_log is turned off
 | 
						|
--echo #
 | 
						|
 | 
						|
SET SESSION slow_query_log=OFF;
 | 
						|
SET GLOBAL slow_query_log=OFF;
 | 
						|
SET long_query_time=0.1;
 | 
						|
 | 
						|
--echo # Although this query is disallowed by slow_query_log, it should still increment Slow_queries
 | 
						|
 | 
						|
--disable_cursor_protocol
 | 
						|
SELECT VARIABLE_VALUE INTO @global_slow_queries
 | 
						|
  FROM INFORMATION_SCHEMA.GLOBAL_STATUS
 | 
						|
  WHERE VARIABLE_NAME='SLOW_QUERIES';
 | 
						|
SELECT sleep(0.2) INTO @tmp FROM DUAL;
 | 
						|
--enable_cursor_protocol
 | 
						|
SELECT
 | 
						|
    CAST(VARIABLE_VALUE AS UNSIGNED)-@global_slow_queries AS Slow_queries_increment
 | 
						|
  FROM
 | 
						|
    INFORMATION_SCHEMA.GLOBAL_STATUS
 | 
						|
  WHERE
 | 
						|
    VARIABLE_NAME='SLOW_QUERIES';
 | 
						|
 | 
						|
--echo # Although this query is disallowed by log_slow_filter, it should still increment Slow_queries
 | 
						|
 | 
						|
SET log_slow_filter=filesort;
 | 
						|
--disable_cursor_protocol
 | 
						|
SELECT sleep(0.2) INTO @tmp FROM DUAL;
 | 
						|
SELECT VARIABLE_VALUE INTO @global_slow_queries
 | 
						|
  FROM INFORMATION_SCHEMA.GLOBAL_STATUS
 | 
						|
  WHERE VARIABLE_NAME='SLOW_QUERIES';
 | 
						|
SELECT sleep(0.2) INTO @tmp FROM DUAL;
 | 
						|
--enable_cursor_protocol
 | 
						|
SELECT
 | 
						|
    CAST(VARIABLE_VALUE AS UNSIGNED)-@global_slow_queries AS Slow_queries_increment
 | 
						|
  FROM
 | 
						|
    INFORMATION_SCHEMA.GLOBAL_STATUS
 | 
						|
  WHERE
 | 
						|
    VARIABLE_NAME='SLOW_QUERIES';
 | 
						|
SET log_slow_filter=DEFAULT;
 | 
						|
 | 
						|
SET @@long_query_time=default;
 | 
						|
SET GLOBAL slow_query_log= @org_slow_query_log;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-21187: log_slow_filter="" logs queries not using indexes
 | 
						|
--echo #
 | 
						|
 | 
						|
flush status;
 | 
						|
create table t (id int);
 | 
						|
insert into t values (1),(4);
 | 
						|
set log_slow_filter='';
 | 
						|
select * from t;
 | 
						|
show session status like 'Slow_queries';
 | 
						|
 | 
						|
drop table t;
 | 
						|
--enable_ps2_protocol
 | 
						|
--enable_cursor_protocol
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # End of 10.3 tests
 | 
						|
--echo #
 | 
						|
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-31742: incorrect examined rows in case of stored function usage
 | 
						|
--echo #
 | 
						|
 | 
						|
 | 
						|
CREATE TABLE `tab_MDEV_30820` (
 | 
						|
`ID` int(11) NOT NULL AUTO_INCREMENT,
 | 
						|
`NAME_F` varchar(50) DEFAULT NULL,
 | 
						|
  PRIMARY KEY (`ID`)
 | 
						|
);
 | 
						|
 | 
						|
 CREATE TABLE `tab2` (
 | 
						|
  `ID` int(11) NOT NULL AUTO_INCREMENT,
 | 
						|
  `TAB1_ID` int(11) DEFAULT NULL,
 | 
						|
  PRIMARY KEY (`id`)
 | 
						|
);
 | 
						|
 | 
						|
--disable_cursor_protocol
 | 
						|
--disable_ps2_protocol
 | 
						|
--disable_view_protocol
 | 
						|
 | 
						|
--delimiter //
 | 
						|
CREATE FUNCTION `get_zero`() RETURNS int(11)
 | 
						|
BEGIN
 | 
						|
    RETURN(0) ;
 | 
						|
END
 | 
						|
//
 | 
						|
 | 
						|
for i in 1..100 do insert into tab_MDEV_30820 values (i,'qwerty'); end for ; //
 | 
						|
for i in 1..1000 do insert into tab2 values (i,i+300); end for ; //
 | 
						|
 | 
						|
--delimiter ;
 | 
						|
 | 
						|
SET @old_slow_query_log= @@global.slow_query_log;
 | 
						|
SET @old_log_output= @@global.log_output;
 | 
						|
SET @old_long_query_time= @@long_query_time;
 | 
						|
SET GLOBAL log_output= "TABLE";
 | 
						|
SET GLOBAL slow_query_log= ON;
 | 
						|
 | 
						|
SET SESSION slow_query_log=ON;
 | 
						|
SET SESSION long_query_time= 0;
 | 
						|
 | 
						|
SELECT 0 as zero, (SELECT ID FROM tab2 where tab2.TAB1_ID =
 | 
						|
tab_MDEV_30820.ID ORDER BY 1 LIMIT 1 ) AS F1 FROM tab_MDEV_30820 ORDER BY 2 DESC LIMIT 2;
 | 
						|
 | 
						|
SELECT get_zero() as zero, (SELECT ID FROM tab2 where tab2.TAB1_ID =
 | 
						|
tab_MDEV_30820.ID ORDER BY 1 LIMIT 1) AS F1 FROM tab_MDEV_30820 ORDER BY 2 DESC LIMIT 2;
 | 
						|
 | 
						|
--echo # should be the same rows_examined
 | 
						|
SELECT rows_examined FROM mysql.slow_log WHERE sql_text LIKE '%SELECT%tab_MDEV_30820%';
 | 
						|
 | 
						|
## Reset to initial values
 | 
						|
SET @@long_query_time= @old_long_query_time;
 | 
						|
SET @@global.log_output= @old_log_output;
 | 
						|
SET @@global.slow_query_log= @old_slow_query_log;
 | 
						|
SET SESSION slow_query_log=default;
 | 
						|
 | 
						|
drop table tab_MDEV_30820, tab2;
 | 
						|
drop function get_zero;
 | 
						|
 | 
						|
--enable_view_protocol
 | 
						|
--enable_ps2_protocol
 | 
						|
--enable_cursor_protocol
 | 
						|
 | 
						|
--echo # End of 10.4 tests
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-34539 Invalid "use" and "Schema" in slow query log file with multi-line schema
 | 
						|
--echo #
 | 
						|
set global log_output='file';
 | 
						|
set @@log_slow_filter= 'not_using_index';
 | 
						|
set slow_query_log=1;
 | 
						|
set timestamp=1234567890;
 | 
						|
create database `a
 | 
						|
b`;
 | 
						|
use `a
 | 
						|
b`;
 | 
						|
create table t1 (a int);
 | 
						|
insert t1 values (1),(2),(3),(4),(5),(6),(7);
 | 
						|
--disable_ps_protocol
 | 
						|
--disable_view_protocol
 | 
						|
select count(*) from t1 where a>2;
 | 
						|
--enable_view_protocol
 | 
						|
--enable_ps_protocol
 | 
						|
drop database `a
 | 
						|
b`;
 | 
						|
use test;
 | 
						|
set global log_output= @old_log_output;
 | 
						|
set slow_query_log=default;
 | 
						|
set log_slow_filter=default;
 | 
						|
set timestamp=default;
 | 
						|
 | 
						|
let SEARCH_FILE=`select @@slow_query_log_file`;
 | 
						|
let SEARCH_PATTERN= use \`a\n.*2;
 | 
						|
let SEARCH_OUTPUT=matches;
 | 
						|
source include/search_pattern_in_file.inc;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-31366 Assertion `thd->start_time' failed in bool LOGGER::slow_log_print(THD*, const char*, size_t, ulonglong)
 | 
						|
--echo #
 | 
						|
 | 
						|
TRUNCATE mysql.slow_log;
 | 
						|
SET global log_output='TABLE';
 | 
						|
SET timestamp=0.99;
 | 
						|
SET long_query_time=0.00001;
 | 
						|
SELECT SLEEP(0.1);
 | 
						|
SELECT COUNT(*)>0 AS c1 FROM mysql.slow_log;
 | 
						|
SET global log_output=default;
 | 
						|
SET timestamp=default;
 | 
						|
SET long_query_time=default;
 | 
						|
TRUNCATE mysql.slow_log;
 | 
						|
 | 
						|
--echo # End of 10.5 tests
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-34251 Conditional jump or move depends on uninitialised value in
 | 
						|
--echo # ha_handler_stats::has_stats
 | 
						|
--echo #
 | 
						|
 | 
						|
set @@global.log_slow_verbosity="";
 | 
						|
connect (con1,localhost,root,,);
 | 
						|
connection con1;
 | 
						|
 | 
						|
# valgrind or asan would notice if engine stats are accessed wrong.
 | 
						|
set long_query_time=0.0, log_slow_verbosity='engine';
 | 
						|
connection default;
 | 
						|
disconnect con1;
 | 
						|
 | 
						|
--echo # End of 10.6 tests
 |