mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-30 18:36:12 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			703 lines
		
	
	
	
		
			21 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			703 lines
		
	
	
	
		
			21 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| # Tests will be skipped for the view protocol because the view protocol creates 
 | |
| # an additional util connection and other statistics data
 | |
| --source include/no_view_protocol.inc
 | |
| --source include/have_stat_tables.inc
 | |
| --source include/have_partition.inc
 | |
| --source include/have_sequence.inc
 | |
| 
 | |
| select @@global.use_stat_tables;
 | |
| select @@session.use_stat_tables;
 | |
| 
 | |
| set @save_use_stat_tables=@@use_stat_tables;
 | |
| set @save_histogram_size=@@global.histogram_size;
 | |
| set @@global.histogram_size=0,@@local.histogram_size=0;
 | |
| set optimizer_use_condition_selectivity=4;
 | |
| 
 | |
| set use_stat_tables='preferably';
 | |
| set @save_histogram_type=@@histogram_type;
 | |
| set histogram_type='single_prec_hb';
 | |
| 
 | |
| --disable_warnings
 | |
| DROP DATABASE IF EXISTS dbt3_s001;
 | |
| --enable_warnings
 | |
| 
 | |
| CREATE DATABASE dbt3_s001;
 | |
| 
 | |
| use dbt3_s001;
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set optimizer_switch='extended_keys=off';
 | |
|  
 | |
| --disable_query_log
 | |
| --disable_result_log
 | |
| --disable_warnings
 | |
| --source include/dbt3_s001.inc
 | |
| create index i_p_retailprice on part(p_retailprice);
 | |
| delete from mysql.table_stats;
 | |
| delete from mysql.column_stats;
 | |
| delete from mysql.index_stats;
 | |
| ANALYZE TABLE
 | |
| customer, lineitem, nation, orders, part, partsupp, region, supplier;
 | |
| FLUSH TABLE mysql.table_stats, mysql.index_stats;
 | |
| --enable_warnings
 | |
| --enable_result_log
 | |
| --enable_query_log
 | |
| 
 | |
| select * from mysql.table_stats;
 | |
| select * from mysql.index_stats;
 | |
| 
 | |
| set optimizer_switch=@save_optimizer_switch; 
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set optimizer_switch='index_condition_pushdown=off';
 | |
| 
 | |
| let $Q5=
 | |
| select n_name, sum(l_extendedprice * (1 - l_discount)) as revenue
 | |
| from customer, orders, lineitem, supplier, nation, region
 | |
| where c_custkey = o_custkey and l_orderkey = o_orderkey
 | |
|       and l_suppkey = s_suppkey and c_nationkey = s_nationkey
 | |
|       and s_nationkey = n_nationkey and n_regionkey = r_regionkey
 | |
|       and r_name = 'AMERICA' and o_orderdate >= date '1995-01-01'
 | |
|       and o_orderdate < date '1995-01-01' + interval '1' year
 | |
| group by n_name
 | |
| order by revenue desc;
 | |
| 
 | |
| eval EXPLAIN $Q5;
 | |
| eval $Q5;
 | |
| 
 | |
| set optimizer_switch=@save_optimizer_switch;
 | |
| 
 | |
| delete from mysql.index_stats;
 | |
| 
 | |
| --disable_query_log
 | |
| --disable_result_log
 | |
| --disable_warnings
 | |
| ANALYZE TABLE
 | |
| customer, lineitem, nation, orders, part, partsupp, region, supplier;
 | |
| FLUSH TABLE mysql.table_stats, mysql.index_stats;
 | |
| --enable_warnings
 | |
| --enable_result_log
 | |
| --enable_query_log
 | |
| 
 | |
| select * from mysql.table_stats;
 | |
| select * from mysql.index_stats;
 | |
| 
 | |
| select * from mysql.table_stats where table_name='orders';
 | |
| select * from mysql.index_stats where table_name='orders';
 | |
| select (select cardinality from mysql.table_stats where table_name='orders') /
 | |
|        (select avg_frequency from mysql.index_stats 
 | |
|           where index_name='i_o_orderdate' and prefix_arity=1) as n_distinct; 
 | |
| select count(distinct o_orderdate) from orders;
 | |
| select (select cardinality from mysql.table_stats where table_name='orders') /
 | |
|        (select avg_frequency from mysql.index_stats 
 | |
|           where index_name='i_o_custkey' and prefix_arity=1) as n_distinct;
 | |
| select count(distinct o_custkey) from orders; 
 | |
| show index from orders;
 | |
| select index_name, column_name, cardinality from information_schema.statistics
 | |
|   where table_name='orders';
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set optimizer_switch='index_condition_pushdown=off';
 | |
| 
 | |
| eval EXPLAIN $Q5;
 | |
| eval $Q5;
 | |
| 
 | |
| set optimizer_switch=@save_optimizer_switch;
 | |
| 
 | |
| let $Q8=
 | |
| select o_year,
 | |
|        sum(case when nation = 'UNITED STATES' then volume else 0 end) /
 | |
|        sum(volume) as mkt_share
 | |
| from (select extract(year from o_orderdate) as o_year,
 | |
|              l_extendedprice * (1-l_discount) as volume, 
 | |
|              n2.n_name as nation
 | |
|       from part, supplier, lineitem, orders, customer, 
 | |
|            nation n1, nation n2, region
 | |
|       where p_partkey = l_partkey and s_suppkey = l_suppkey
 | |
|             and l_orderkey = o_orderkey and o_custkey = c_custkey
 | |
|             and c_nationkey = n1.n_nationkey and n1.n_regionkey = r_regionkey
 | |
|             and r_name = 'AMERICA' and s_nationkey = n2.n_nationkey
 | |
|             and o_orderdate between date '1995-01-01' and date '1996-12-31'
 | |
|             and p_type = 'STANDARD BRUSHED STEEL' ) as all_nations
 | |
| group by o_year
 | |
| order by o_year;
 | |
| 
 | |
| eval EXPLAIN $Q8;
 | |
| eval $Q8;
 | |
| 
 | |
| let $Q9=
 | |
| select nation, o_year, sum(amount) as sum_profit
 | |
| from (select n_name as nation, 
 | |
|       extract(year from o_orderdate) as o_year,
 | |
|       l_extendedprice * (1 - l_discount) - ps_supplycost * l_quantity as amount
 | |
|       from part, supplier, lineitem, partsupp, orders, nation
 | |
|       where s_suppkey = l_suppkey and ps_suppkey = l_suppkey
 | |
|             and ps_partkey = l_partkey and p_partkey = l_partkey
 | |
|             and o_orderkey = l_orderkey and s_nationkey = n_nationkey
 | |
|             and p_name like '%green%') as profit
 | |
| group by nation, o_year
 | |
| order by nation, o_year desc;
 | |
| 
 | |
| eval EXPLAIN $Q9;
 | |
| eval EXPLAIN EXTENDED $Q9;
 | |
| eval $Q9;
 | |
| 
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set optimizer_switch='extended_keys=on';
 | |
| 
 | |
| let $QQ1=
 | |
| select o_orderkey, p_partkey
 | |
|   from part, lineitem, orders
 | |
|   where p_retailprice > 1100 and o_orderdate='1997-01-01' 
 | |
|         and o_orderkey=l_orderkey and p_partkey=l_partkey;
 | |
| 
 | |
| eval EXPLAIN $QQ1;
 | |
| eval $QQ1;
 | |
| 
 | |
| set optimizer_switch=@save_optimizer_switch;
 | |
| 
 | |
| 
 | |
| DROP DATABASE dbt3_s001;
 | |
| 
 | |
| use test;
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug mdev-473: ANALYZE table locked for write
 | |
| --echo # 
 | |
| 
 | |
| set use_stat_tables='complementary';
 | |
| 
 | |
| create table t1 (i int);
 | |
| 
 | |
| lock table t1 write;
 | |
| analyze table t1;
 | |
| alter table t1 add column a varchar(8);
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug mdev-487: memory leak in ANALYZE with stat tables
 | |
| --echo # 
 | |
| 
 | |
| SET  use_stat_tables = 'preferably';
 | |
| 
 | |
| CREATE TABLE t1 (a INT);
 | |
| INSERT INTO t1 VALUES (1),(2);
 | |
| DELETE FROM t1 WHERE a=1;
 | |
| 
 | |
| ANALYZE TABLE t1;
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug mdev-518: corrupted/missing statistical tables
 | |
| --echo # 
 | |
| 
 | |
| CREATE TABLE t1 (i int) ENGINE=MyISAM;
 | |
| INSERT INTO t1 VALUES (1),(2);
 | |
| 
 | |
| FLUSH TABLE t1;
 | |
| SET use_stat_tables='never';
 | |
| EXPLAIN SELECT * FROM t1;
 | |
| 
 | |
| --move_file $MYSQLTEST_VARDIR/mysqld.1/data/mysql/table_stats.MAD $MYSQLTEST_VARDIR/mysqld.1/data/mysql/table_stats.MAD.save
 | |
| 
 | |
| FLUSH TABLES;
 | |
| SET use_stat_tables='preferably';
 | |
| --disable_warnings
 | |
| EXPLAIN SELECT * FROM t1;
 | |
| --enable_warnings
 | |
| 
 | |
| # Cleanup
 | |
| --move_file $MYSQLTEST_VARDIR/mysqld.1/data/mysql/table_stats.MAD.save $MYSQLTEST_VARDIR/mysqld.1/data/mysql/table_stats.MAD
 | |
| DROP TABLE t1;
 | |
| 
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug mdev-5204: invalid impossible where after reading const tables  
 | |
| --echo #                when use_stat_tables = 'preferably'
 | |
| --echo #
 | |
| 
 | |
| set use_stat_tables = 'preferably';
 | |
| 
 | |
| CREATE TABLE t1 (id int PRIMARY KEY) ENGINE=MyISAM;
 | |
| INSERT INTO t1 VALUES (1),(2);
 | |
| ANALYZE TABLE t1;
 | |
| 
 | |
| CREATE TABLE t2 (name char(3)) ENGINE=MyISAM;
 | |
| ANALYZE TABLE t2;
 | |
| INSERT INTO t2 VALUES ('USA'),('AUS');
 | |
| 
 | |
| SELECT * FROM t1 STRAIGHT_JOIN t2 WHERE name IN ( 'AUS','YEM' ) AND id = 1;
 | |
| EXPLAIN
 | |
| SELECT * FROM t1 STRAIGHT_JOIN t2 WHERE name IN ( 'AUS','YEM' ) AND id = 1;
 | |
| 
 | |
| ANALYZE TABLE t2;
 | |
| 
 | |
| SELECT * FROM t1 STRAIGHT_JOIN t2 WHERE name IN ( 'AUS','YEM' ) AND id = 1;
 | |
| EXPLAIN
 | |
| SELECT * FROM t1 STRAIGHT_JOIN t2 WHERE name IN ( 'AUS','YEM' ) AND id = 1;
 | |
| 
 | |
| DROP TABLE t1,t2;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-7370: Server deadlocks on renaming a table for which persistent statistics exists
 | |
| --echo #
 | |
| 
 | |
| --disable_warnings
 | |
| drop database if exists db1;
 | |
| drop database if exists db1;
 | |
| --enable_warnings
 | |
| 
 | |
| create database db1;
 | |
| create database db2;
 | |
| use db1;
 | |
| --echo #
 | |
| --echo # First, run the original testcase:
 | |
| --echo #
 | |
| create table t1 (i int);
 | |
| insert into t1 values (10),(20);
 | |
| analyze table t1 persistent for all;
 | |
| rename table t1 to db2.t1;
 | |
| 
 | |
| --echo # Verify that stats in the old database are gone:
 | |
| select * from mysql.column_stats where db_name='db1' and table_name='t1';
 | |
| select * from mysql.table_stats where db_name='db1' and table_name='t1';
 | |
| 
 | |
| --echo # Verify that stats are present in the new database:
 | |
| select * from mysql.column_stats where db_name='db2' and table_name='t1';
 | |
| select * from mysql.table_stats where db_name='db2' and table_name='t1';
 | |
| 
 | |
| 
 | |
| --echo #
 | |
| --echo # Now, try with more than one column and with indexes:
 | |
| --echo #
 | |
| use test;
 | |
| create table t1(a int primary key);
 | |
| insert into t1 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
 | |
| 
 | |
| 
 | |
| use db1;
 | |
| create table t2 (a int, b int, c int, key IDX1(a), key IDX2(a,b));
 | |
| insert into t2 select a/10, a/2, a from test.t1;
 | |
| analyze table t2 persistent for all;
 | |
| 
 | |
| alter table t2 rename db2.t2;
 | |
| 
 | |
| --echo # Verify that stats in the old database are gone:
 | |
| select * from mysql.table_stats where db_name='db1' and table_name='t2';
 | |
| select * from mysql.column_stats where db_name='db1' and table_name='t2';
 | |
| select * from mysql.index_stats where db_name='db1' and table_name='t2';
 | |
| 
 | |
| --echo # Verify that stats are present in the new database:
 | |
| select * from mysql.table_stats where db_name='db2' and table_name='t2';
 | |
| select * from mysql.column_stats where db_name='db2' and table_name='t2';
 | |
| select * from mysql.index_stats where db_name='db2' and table_name='t2';
 | |
| 
 | |
| use db2;
 | |
| --echo #
 | |
| --echo # Now, rename within the same database and verify:
 | |
| --echo #
 | |
| rename table t2 to t3;
 | |
| --echo # No stats under old name:
 | |
| select * from mysql.table_stats where db_name='db2' and table_name='t2';
 | |
| select * from mysql.column_stats where db_name='db2' and table_name='t2';
 | |
| select * from mysql.index_stats where db_name='db2' and table_name='t2';
 | |
| --echo # Stats under the new name:
 | |
| select * from mysql.table_stats where db_name='db2' and table_name='t3';
 | |
| select * from mysql.column_stats where db_name='db2' and table_name='t3';
 | |
| select * from mysql.index_stats where db_name='db2' and table_name='t3';
 | |
| 
 | |
| use test;
 | |
| drop database db1;
 | |
| drop database db2;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16552: [10.0] ASAN global-buffer-overflow in is_stat_table / statistics_for_tables_is_needed
 | |
| --echo #
 | |
| 
 | |
| SET use_stat_tables = PREFERABLY;
 | |
| SELECT CONVERT_TZ( '1991-09-20 10:11:02', '+00:00', 'GMT' );
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16757: manual addition of min/max statistics for BLOB
 | |
| --echo #
 | |
| 
 | |
| SET use_stat_tables= PREFERABLY;
 | |
| 
 | |
| CREATE TABLE t1 (pk INT PRIMARY KEY, t TEXT);
 | |
| INSERT INTO t1 VALUES (1,'foo'),(2,'bar');
 | |
| ANALYZE TABLE t1;
 | |
| --sorted_result
 | |
| SELECT * FROM mysql.column_stats;
 | |
| DELETE FROM mysql.column_stats
 | |
|   WHERE db_name='test' AND table_name='t1' AND column_name='t';
 | |
| INSERT INTO mysql.column_stats VALUES
 | |
|   ('test','t1','t','bar','foo', 0.0, 3.0, 1.0, 0, NULL, NULL);
 | |
| --sorted_result
 | |
| SELECT * FROM mysql.column_stats;
 | |
| 
 | |
| SELECT pk FROM t1;
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16760: CREATE OR REPLACE TABLE after ANALYZE TABLE
 | |
| --echo #
 | |
| 
 | |
| SET use_stat_tables= PREFERABLY;
 | |
| 
 | |
| CREATE TABLE t1 (pk int PRIMARY KEY, c varchar(32));
 | |
| INSERT INTO t1 VALUES (1,'foo'),(2,'bar');
 | |
| ANALYZE TABLE t1;
 | |
| SELECT * FROM t1;
 | |
| SELECT * FROM mysql.column_stats;
 | |
| 
 | |
| CREATE OR REPLACE TABLE t1 (pk int PRIMARY KEY, a char(7));
 | |
| SELECT * FROM t1;
 | |
| SELECT * FROM mysql.column_stats;
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17023: Crash during read_histogram_for_table with optimizer_use_condition_selectivity set to 4
 | |
| --echo #
 | |
| 
 | |
| set @save_optimizer_use_condition_selectivity=@@optimizer_use_condition_selectivity;
 | |
| set @@optimizer_use_condition_selectivity=4;
 | |
| set @@use_stat_tables= PREFERABLY;
 | |
| explain
 | |
| SELECT * FROM INFORMATION_SCHEMA.PROFILING, mysql.user;
 | |
| set @@optimizer_use_condition_selectivity=@save_optimizer_use_condition_selectivity;
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17734: AddressSanitizer: use-after-poison in create_key_parts_for_pseudo_indexes
 | |
| --echo #
 | |
| 
 | |
| set @@use_stat_tables= PREFERABLY;
 | |
| set @save_optimizer_use_condition_selectivity= @@optimizer_use_condition_selectivity;
 | |
| set @@optimizer_use_condition_selectivity=4;
 | |
| set @save_use_stat_tables= @@use_stat_tables;
 | |
| create table t1 (a int, b int);
 | |
| insert into t1(a,b) values (1,2),(1,3),(1,4),(1,5),(2,6),(2,7),(3,8),(3,9),(3,9),(4,10);
 | |
| 
 | |
| analyze table t1 persistent for columns (a) indexes ();
 | |
| select * from t1 where a=1 and b=3;
 | |
| set @@optimizer_use_condition_selectivity= @save_optimizer_use_condition_selectivity;
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16711:CREATE OR REPLACE TABLE introducing BLOB column
 | |
| --echo #
 | |
| 
 | |
| SET use_stat_tables= PREFERABLY;
 | |
| 
 | |
| CREATE TABLE t1 (pk INT PRIMARY KEY, t CHAR(60));
 | |
| INSERT INTO t1 VALUES (1,'foo'),(2,'bar');
 | |
| ANALYZE TABLE t1;
 | |
| CREATE OR REPLACE TABLE t1 (pk INT PRIMARY KEY, t TEXT);
 | |
| 
 | |
| SELECT MAX(pk) FROM t1;
 | |
| 
 | |
| DROP TABLE t1;
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| 
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17605: SHOW INDEXES with use_stat_tables='preferably'
 | |
| --echo #
 | |
| 
 | |
| set use_stat_tables='preferably';
 | |
| 
 | |
| CREATE DATABASE dbt3_s001;
 | |
| 
 | |
| use dbt3_s001;
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set optimizer_switch='extended_keys=off';
 | |
| 
 | |
| --disable_query_log
 | |
| --disable_result_log
 | |
| --disable_warnings
 | |
| --source include/dbt3_s001.inc
 | |
| create index i_p_retailprice on part(p_retailprice);
 | |
| delete from mysql.table_stats;
 | |
| delete from mysql.column_stats;
 | |
| delete from mysql.index_stats;
 | |
| ANALYZE TABLE lineitem;
 | |
| FLUSH TABLE mysql.table_stats, mysql.index_stats;
 | |
| --enable_warnings
 | |
| --enable_result_log
 | |
| --enable_query_log
 | |
| 
 | |
| select * from mysql.table_stats;
 | |
| select * from mysql.index_stats;
 | |
| 
 | |
| SHOW INDEXES FROM lineitem;
 | |
| 
 | |
| SELECT * FROM INFORMATION_SCHEMA.STATISTICS WHERE table_name='lineitem';
 | |
| 
 | |
| SELECT
 | |
|   COUNT(DISTINCT l_orderkey), COUNT(DISTINCT l_orderkey,l_linenumber),
 | |
|   COUNT(DISTINCT l_shipDATE),
 | |
|   COUNT(DISTINCT l_partkey), COUNT(DISTINCT l_partkey,l_suppkey),
 | |
|   COUNT(DISTINCT l_suppkey), COUNT(DISTINCT l_receiptDATE),
 | |
|   COUNT(DISTINCT l_orderkey, l_quantity), COUNT(DISTINCT l_commitDATE)
 | |
| FROM lineitem;
 | |
| 
 | |
| set optimizer_switch=@save_optimizer_switch;
 | |
| 
 | |
| DROP DATABASE dbt3_s001;
 | |
| USE test;
 | |
| 
 | |
| delete from mysql.table_stats;
 | |
| delete from mysql.column_stats;
 | |
| delete from mysql.index_stats;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-19352: Server crash in alloc_histograms_for_table_share upon query from information schema
 | |
| --echo #
 | |
| 
 | |
| use test;
 | |
| set @save_optimizer_use_condition_selectivity= @@optimizer_use_condition_selectivity;
 | |
| set @@optimizer_use_condition_selectivity= 4;
 | |
| set use_stat_tables='preferably';
 | |
| 
 | |
| CREATE TABLE t1 (a INT);
 | |
| CREATE TABLE t2 (b INT);
 | |
| CREATE VIEW v AS SELECT * FROM t1 JOIN t2;
 | |
| --error ER_NO_SUCH_TABLE
 | |
| INSERT INTO t2 SELECT * FROM x;
 | |
| 
 | |
| select * from information_schema.tables where table_name='v';
 | |
| set @@optimizer_use_condition_selectivity= @save_optimizer_use_condition_selectivity;
 | |
| 
 | |
| drop table t1,t2;
 | |
| drop view v;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-19407: Assertion `field->table->stats_is_read' failed in is_eits_usable
 | |
| --echo #
 | |
| 
 | |
| set @save_optimizer_use_condition_selectivity= @@optimizer_use_condition_selectivity;
 | |
| set @@optimizer_use_condition_selectivity= 1;
 | |
| set @@use_stat_tables='never';
 | |
| create table t1(pk int);
 | |
| insert into t1 values (4),(3);
 | |
| set @@optimizer_use_condition_selectivity= 4;
 | |
| set use_stat_tables='preferably';
 | |
| 
 | |
| --error ER_NO_SUCH_TABLE
 | |
| INSERT INTO t1 SELECT * FROM x;
 | |
| CREATE TABLE t2 SELECT pk FROM t1 WHERE pk>2;
 | |
| select * from t2;
 | |
| drop table t1,t2;
 | |
| 
 | |
| create table t1(a int,b int, key k1(a) );
 | |
| insert into t1 values(1,1),(2,2),(3,3);
 | |
| analyze table t1;
 | |
| select * from mysql.index_stats, t1 where index_name='k1' and t1.a > 1 and t1.b > 1;
 | |
| drop table t1;
 | |
| 
 | |
| set @@optimizer_use_condition_selectivity= @save_optimizer_use_condition_selectivity;
 | |
| 
 | |
| set @save_optimizer_switch=@@optimizer_switch;
 | |
| set use_stat_tables=@save_use_stat_tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-18899: Server crashes in Field::set_warning_truncated_wrong_value
 | |
| --echo #
 | |
| 
 | |
| set names utf8;
 | |
| set @save_optimizer_use_condition_selectivity=@@optimizer_use_condition_selectivity;
 | |
| set optimizer_use_condition_selectivity=4;
 | |
| set use_stat_tables=preferably;
 | |
| set histogram_size=255;
 | |
| 
 | |
| create table t1 ( a varchar(255) character set utf8);
 | |
| insert into t1 values (REPEAT('ӥ',255)), (REPEAT('ç',255));
 | |
| 
 | |
| analyze table t1;
 | |
| select HEX(RIGHT(min_value, 1)), length(min_value) from mysql.column_stats where db_name='test' and table_name='t1';
 | |
| select HEX(RIGHT(max_value, 1)), length(max_value) from mysql.column_stats where db_name='test' and table_name='t1';
 | |
| analyze select * from t1 where a  >= 'ӥ';
 | |
| 
 | |
| set @save_sql_mode= @@sql_mode;
 | |
| set sql_mode='ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
 | |
| update mysql.column_stats set min_value= REPEAT('ӥ',255) where db_name='test' and table_name='t1';
 | |
| select HEX(RIGHT(min_value, 1)), length(min_value) from mysql.column_stats where db_name='test' and table_name='t1';
 | |
| analyze select * from t1 where a  >= 'ӥ';
 | |
| 
 | |
| set names latin1;
 | |
| drop table t1;
 | |
| 
 | |
| CREATE TABLE t1 (col1 date);
 | |
| INSERT INTO t1 VALUES('2004-01-01'),('2004-02-29');
 | |
| INSERT INTO t1 VALUES('0000-10-31');
 | |
| analyze table t1;
 | |
| update mysql.column_stats set min_value='2004-0-31123' where db_name='test' and table_name='t1';
 | |
| select min_value from mysql.column_stats where db_name='test' and table_name='t1';
 | |
| select * from t1;
 | |
| set @@sql_mode= @save_sql_mode;
 | |
| set @@use_stat_tables=@save_use_stat_tables;
 | |
| set @@histogram_size= @save_histogram_size;
 | |
| set @@histogram_type=@save_histogram_type;
 | |
| set @@optimizer_use_condition_selectivity=@save_optimizer_use_condition_selectivity;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-20589: Server still crashes in Field::set_warning_truncated_wrong_value
 | |
| --echo #
 | |
| 
 | |
| set names utf8;
 | |
| create table t1 ( a varchar(255) character set utf8);
 | |
| insert into t1 values (REPEAT('ӥ',255)), (REPEAT('ç',255));
 | |
| 
 | |
| set use_stat_tables='preferably';
 | |
| analyze table t1 persistent for all;
 | |
| 
 | |
| set @save_sql_mode= @@sql_mode;
 | |
| set sql_mode='ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
 | |
| update mysql.column_stats set min_value= REPEAT('ӥ',256) where db_name='test' and table_name='t1';
 | |
| set @@sql_mode= @save_sql_mode;
 | |
| 
 | |
| select length(a) from t1 where a=REPEAT('ӥ',255);
 | |
| 
 | |
| set names latin1;
 | |
| set @@use_stat_tables=@save_use_stat_tables;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-23753: SIGSEGV in Column_stat::store_stat_fields
 | |
| --echo #
 | |
| 
 | |
| CREATE TABLE t1 (a INT, b INT) PARTITION BY HASH (b) PARTITIONS 2;
 | |
| LOCK TABLES t1 WRITE;
 | |
| ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (a) INDEXES ();
 | |
| ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (nonexisting) INDEXES (nonexisting);
 | |
| DROP TABLE t1;
 | |
| 
 | |
| 
 | |
| --echo # please keep this at the last
 | |
| set @@global.histogram_size=@save_histogram_size;
 | |
| 
 | |
| --echo # Start of 10.4 tests
 | |
| 
 | |
| set histogram_size=0;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17255: New optimizer defaults and ANALYZE TABLE
 | |
| --echo #
 | |
| 
 | |
| create table t1 (a int, b int);
 | |
| insert into t1(a,b) values (1,2),(1,3),(1,4),(1,5),(2,6),(2,7),(3,8),(3,9),(3,9),(4,10);
 | |
| set use_stat_tables= preferably_for_queries;
 | |
| --echo #
 | |
| --echo # with use_stat_tables= PREFERABLY_FOR_QUERIES
 | |
| --echo # analyze table t1 will not collect statistics
 | |
| --echo #
 | |
| 
 | |
| analyze table t1;
 | |
| select * from mysql.column_stats;
 | |
| analyze
 | |
| select * from t1 where a = 1 and b=3;
 | |
| 
 | |
| --echo #
 | |
| --echo # with use_stat_tables= PREFERABLY_FOR_QUERIES
 | |
| --echo # analyze table t1 will  collect statistics if we use PERSISTENT
 | |
| --echo # for columns, indexes or everything
 | |
| --echo #
 | |
| 
 | |
| analyze table t1 persistent for columns (a) indexes ();
 | |
| select * from mysql.column_stats;
 | |
| --echo # filtered shows that we used the data from stat tables
 | |
| analyze
 | |
| select * from t1 where a = 1 and b=3;
 | |
| 
 | |
| --echo #
 | |
| --echo # with use_stat_tables= PREFERABLY
 | |
| --echo # analyze table t1 will collect statistics
 | |
| --echo #
 | |
| 
 | |
| set use_stat_tables=PREFERABLY;
 | |
| analyze table t1;
 | |
| select * from mysql.column_stats;
 | |
| --echo # filtered shows that we used the data from stat tables
 | |
| analyze
 | |
| select * from t1 where a=1 and b=3;
 | |
| drop table t1;
 | |
| 
 | |
| set @@global.histogram_size=@save_histogram_size;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.4 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-29693 ANALYZE TABLE still flushes table definition cache
 | |
| --echo # when engine-independent statistics is used
 | |
| --echo #
 | |
| 
 | |
| create table t1 (a int);
 | |
| insert into t1 select seq from seq_0_to_99;
 | |
| analyze table t1 persistent for all;
 | |
| analyze table t1 persistent for all;
 | |
| 
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| 
 | |
| connect (con1, localhost, root,,);
 | |
| --connection con1
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| 
 | |
| let $open_tables=`select variable_value from information_schema.global_status where variable_name="OPENED_TABLES"`;
 | |
| 
 | |
| --connection default
 | |
| update t1 set a= a +100;
 | |
| 
 | |
| --echo # Explain shows outdated statistics:
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| --connection con1
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| 
 | |
| --connection default
 | |
| analyze table t1 persistent for all;
 | |
| --echo # Now explain shows updated statistics:
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| --connection con1
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| 
 | |
| --connection con1
 | |
| --echo # Run update and analyze in con1:
 | |
| update t1 set a= a - 150;
 | |
| analyze table t1 persistent for all;
 | |
| 
 | |
| --connection default
 | |
| --echo # Explain shows updated statistics:
 | |
| explain extended select count(*) from t1 where a < 50;
 | |
| 
 | |
| disconnect con1;
 | |
| 
 | |
| let $new_open_tables=`select variable_value from information_schema.global_status where variable_name="OPENED_TABLES"`;
 | |
| 
 | |
| if ($open_tables != $new_open_tables)
 | |
| {
 | |
| --let $diff=`select $new_open_tables - $open_tables`
 | |
| --echo "Fail: Test opened $diff new tables, 0 was expected"
 | |
| }
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.6 tests
 | |
| --echo #
 | 
