mirror of
https://github.com/MariaDB/server.git
synced 2025-11-09 11:41:36 +03:00
Raise notes if indexes cannot be used:
- in case of data type or collation mismatch (diferent error messages).
- in case if a table field was replaced to something else
(e.g. Item_func_conv_charset) during a condition rewrite.
Added option to write warnings and notes to the slow query log for
slow queries.
New variables added/changed:
- note_verbosity, with is a set of the following options:
basic - All old notes
unusable_keys - Print warnings about keys that cannot be used
for select, delete or update.
explain - Print unusable_keys warnings for EXPLAIN querys.
The default is 'basic,explain'. This means that for old installations
the only notable new behavior is that one will get notes about
unusable keys when one does an EXPLAIN for a query. One can turn all
of all notes by either setting note_verbosity to "" or setting sql_notes=0.
- log_slow_verbosity has a new option 'warnings'. If this is set
then warnings and notes generated are printed in the slow query log
(up to log_slow_max_warnings times per statement).
- log_slow_max_warnings - Max number of warnings written to
slow query log.
Other things:
- One can now use =ALL for any 'set' variable to set all options at once.
For example using "note_verbosity=ALL" in a config file or
"SET @@note_verbosity=ALL' in SQL.
- mysqldump will in the future use @@note_verbosity=""' instead of
@sql_notes=0 to disable notes.
- Added "enum class Data_type_compatibility" and changing the return type
of all Field::can_optimize*() methods from "bool" to this new data type.
Reviewer & Co-author: Alexander Barkov <bar@mariadb.com>
- The code that prints out the notes comes mainly from Alexander
99 lines
3.3 KiB
Plaintext
99 lines
3.3 KiB
Plaintext
SET @start_global_value = @@global.log_slow_verbosity;
|
|
select @@global.log_slow_verbosity = @@session.log_slow_verbosity;
|
|
@@global.log_slow_verbosity = @@session.log_slow_verbosity
|
|
1
|
|
SET @@global.log_slow_verbosity="",@@session.log_slow_verbosity="";
|
|
show global variables like 'log_slow_verbosity';
|
|
Variable_name Value
|
|
log_slow_verbosity
|
|
show session variables like 'log_slow_verbosity';
|
|
Variable_name Value
|
|
log_slow_verbosity
|
|
select * from information_schema.global_variables where variable_name='log_slow_verbosity';
|
|
VARIABLE_NAME VARIABLE_VALUE
|
|
LOG_SLOW_VERBOSITY
|
|
select * from information_schema.session_variables where variable_name='log_slow_verbosity';
|
|
VARIABLE_NAME VARIABLE_VALUE
|
|
LOG_SLOW_VERBOSITY
|
|
set global log_slow_verbosity=1;
|
|
select @@global.log_slow_verbosity;
|
|
@@global.log_slow_verbosity
|
|
innodb
|
|
set session log_slow_verbosity=1;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb
|
|
set session log_slow_verbosity=1;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb
|
|
set session log_slow_verbosity=2;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
query_plan
|
|
set session log_slow_verbosity=3;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb,query_plan
|
|
set session log_slow_verbosity=4;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
explain
|
|
set session log_slow_verbosity=5;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb,explain
|
|
set session log_slow_verbosity=6;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
query_plan,explain
|
|
set session log_slow_verbosity=7;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb,query_plan,explain
|
|
set session log_slow_verbosity=8;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
engine
|
|
set session log_slow_verbosity=16;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
warnings
|
|
set session log_slow_verbosity=32;
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
full
|
|
set session log_slow_verbosity='innodb';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb
|
|
set session log_slow_verbosity='query_plan';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
query_plan
|
|
set session log_slow_verbosity='innodb,query_plan';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb,query_plan
|
|
set session log_slow_verbosity='explain';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
explain
|
|
set session log_slow_verbosity='innodb,query_plan,explain,engine,warnings,full';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
innodb,query_plan,explain,engine,warnings,full
|
|
set session log_slow_verbosity='';
|
|
select @@session.log_slow_verbosity;
|
|
@@session.log_slow_verbosity
|
|
|
|
set session log_slow_verbosity=1.1;
|
|
ERROR 42000: Incorrect argument type to variable 'log_slow_verbosity'
|
|
set session log_slow_verbosity=1e1;
|
|
ERROR 42000: Incorrect argument type to variable 'log_slow_verbosity'
|
|
set session log_slow_verbosity="foo";
|
|
ERROR 42000: Variable 'log_slow_verbosity' can't be set to the value of 'foo'
|
|
set session log_slow_verbosity=64;
|
|
ERROR 42000: Variable 'log_slow_verbosity' can't be set to the value of '64'
|
|
SET @@global.log_slow_verbosity = @start_global_value;
|