mirror of
https://github.com/MariaDB/server.git
synced 2025-08-09 22:24:09 +03:00
Making the stat_tables_innodb test deterministic
This commit is contained in:
@@ -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;
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
--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;
|
|||||||
--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;
|
||||||
|
Reference in New Issue
Block a user