Commit c400ef25 authored by Varun Gupta's avatar Varun Gupta

Making the stat_tables_innodb test deterministic

parent 1ba8df4c
...@@ -773,30 +773,25 @@ set optimizer_switch=@save_optimizer_switch_for_stat_tables_test; ...@@ -773,30 +773,25 @@ set optimizer_switch=@save_optimizer_switch_for_stat_tables_test;
# #
# MDEV-22851: Engine independent index statistics are incorrect for large tables on Windows. # MDEV-22851: Engine independent index statistics are incorrect for large tables on Windows.
# #
CREATE TABLE t1 AS SELECT TABLE_CATALOG FROM INFORMATION_SCHEMA.COLUMNS; CREATE TABLE t1(a INT) ENGINE=INNODB;
INSERT INTO t1 SELECT * FROM t1; INSERT INTO t1 SELECT 1 FROM seq_1_to_60000;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
SET @save_use_stat_tables= @@use_stat_tables; SET @save_use_stat_tables= @@use_stat_tables;
SET use_stat_tables= preferably; SET use_stat_tables= preferably;
SELECT count(*) FROM t1; SELECT count(*) FROM t1;
count(*) count(*)
54336 60000
CREATE INDEX idx ON t1(TABLE_CATALOG); CREATE INDEX idx ON t1(a);
Warnings: ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (a) INDEXES (idx);
Warning 1071 Specified key was too long; max key length is 767 bytes
ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (TABLE_CATALOG) INDEXES (idx);
Table Op Msg_type Msg_text Table Op Msg_type Msg_text
test.t1 analyze status Engine-independent statistics collected test.t1 analyze status Engine-independent statistics collected
test.t1 analyze status OK test.t1 analyze status OK
SELECT * FROM mysql.index_stats where table_name='t1'; SELECT * FROM mysql.index_stats where table_name='t1';
db_name table_name index_name prefix_arity avg_frequency db_name table_name index_name prefix_arity avg_frequency
test t1 idx 1 NULL test t1 idx 1 60000.0000
SELECT * FROM mysql.column_stats where table_name='t1'; SELECT * FROM mysql.column_stats where table_name='t1';
db_name table_name column_name min_value max_value nulls_ratio avg_length avg_frequency hist_size hist_type histogram db_name table_name column_name min_value max_value nulls_ratio avg_length avg_frequency hist_size hist_type histogram
test t1 TABLE_CATALOG def def 0.0000 3.0000 54336.0000 0 NULL NULL test t1 a 1 1 0.0000 4.0000 60000.0000 0 NULL NULL
SET use_stat_tables= @save_use_stat_tables; SET use_stat_tables= @save_use_stat_tables;
DROP TABLE t1; DROP TABLE t1;
# end of 10.1 tests
SET SESSION STORAGE_ENGINE=DEFAULT; SET SESSION STORAGE_ENGINE=DEFAULT;
--source include/have_innodb.inc --source include/have_innodb.inc
--source include/have_sequence.inc
SET SESSION STORAGE_ENGINE='InnoDB'; SET SESSION STORAGE_ENGINE='InnoDB';
...@@ -13,21 +14,19 @@ set optimizer_switch=@save_optimizer_switch_for_stat_tables_test; ...@@ -13,21 +14,19 @@ set optimizer_switch=@save_optimizer_switch_for_stat_tables_test;
--echo # MDEV-22851: Engine independent index statistics are incorrect for large tables on Windows. --echo # MDEV-22851: Engine independent index statistics are incorrect for large tables on Windows.
--echo # --echo #
CREATE TABLE t1 AS SELECT TABLE_CATALOG FROM INFORMATION_SCHEMA.COLUMNS; CREATE TABLE t1(a INT) ENGINE=INNODB;
INSERT INTO t1 SELECT * FROM t1; INSERT INTO t1 SELECT 1 FROM seq_1_to_60000;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
SET @save_use_stat_tables= @@use_stat_tables; SET @save_use_stat_tables= @@use_stat_tables;
SET use_stat_tables= preferably; SET use_stat_tables= preferably;
SELECT count(*) FROM t1; SELECT count(*) FROM t1;
CREATE INDEX idx ON t1(TABLE_CATALOG); CREATE INDEX idx ON t1(a);
ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (TABLE_CATALOG) INDEXES (idx); ANALYZE TABLE t1 PERSISTENT FOR COLUMNS (a) INDEXES (idx);
SELECT * FROM mysql.index_stats where table_name='t1'; SELECT * FROM mysql.index_stats where table_name='t1';
SELECT * FROM mysql.column_stats where table_name='t1'; SELECT * FROM mysql.column_stats where table_name='t1';
SET use_stat_tables= @save_use_stat_tables; SET use_stat_tables= @save_use_stat_tables;
DROP TABLE t1; DROP TABLE t1;
--echo # end of 10.1 tests
SET SESSION STORAGE_ENGINE=DEFAULT; SET SESSION STORAGE_ENGINE=DEFAULT;
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment