# # Test information_schema.innodb_cmp_per_index # -- source include/have_innodb.inc # Using innodb_log_compressed=0 leads to a larger number of page # compressions, because page_cur_insert_rec_zip() will reorganize the # page before attempting an insert followed by page compression and # page_zip_compress_write_log_no_data(). if (`SELECT @@innodb_log_compressed_pages = 0`) { --skip Needs innodb_log_compressed_pages } # numbers read in this test depend on the page size -- source include/have_innodb_16k.inc # include/restart_mysqld.inc does not work in embedded mode -- source include/not_embedded.inc -- vertical_results SET GLOBAL innodb_cmp_per_index_enabled=ON; SET GLOBAL innodb_file_format=Barracuda; # reset any leftover stats from previous tests -- disable_query_log -- disable_result_log SELECT * FROM information_schema.innodb_cmp_per_index_reset; -- enable_result_log -- enable_query_log # see that the table is empty SELECT * FROM information_schema.innodb_cmp_per_index; # create a table that uses compression CREATE TABLE t ( a INT, b VARCHAR(512), c VARCHAR(16), PRIMARY KEY (a), INDEX (b(512)), INDEX (c(16)) ) ENGINE=INNODB KEY_BLOCK_SIZE=2; SELECT database_name, table_name, index_name, compress_ops, compress_ops_ok, uncompress_ops FROM information_schema.innodb_cmp_per_index ORDER BY 1, 2, 3; # insert some data into it BEGIN; -- disable_query_log let $i=128; while ($i) { -- eval INSERT INTO t VALUES ($i, REPEAT('x', 512), NULL); dec $i; } -- enable_query_log COMMIT; ALTER TABLE t DROP INDEX c; GRANT USAGE ON *.* TO 'tuser01'@'localhost' IDENTIFIED BY 'cDJvI9s_Uq'; FLUSH PRIVILEGES; -- connect (con1,localhost,tuser01,cDJvI9s_Uq,) -- connection con1 -- error ER_SPECIFIC_ACCESS_DENIED_ERROR SELECT * FROM information_schema.innodb_cmp_per_index; -- connection default -- disconnect con1 DROP USER 'tuser01'@'localhost'; -- replace_regex /index_id:[0-9]+/index_id:idisnondeterministic/ SELECT database_name, table_name, index_name, CASE WHEN compress_ops=47 and @@innodb_compression_level IN (4,8,9) THEN 65 ELSE compress_ops END as compress_ops, CASE WHEN compress_ops_ok=47 and @@innodb_compression_level IN (4,8,9) THEN 65 ELSE compress_ops_ok END as compress_ops_ok, uncompress_ops FROM information_schema.innodb_cmp_per_index ORDER BY 1, 2, 3; # restart mysqld and see that uncompress ops also gets increased when # selecting from the table again -- source include/restart_mysqld.inc SET GLOBAL innodb_cmp_per_index_enabled=ON; SELECT COUNT(*) FROM t; SELECT database_name, table_name, index_name, compress_ops, compress_ops_ok, uncompress_ops FROM information_schema.innodb_cmp_per_index ORDER BY 1, 2, 3; DROP TABLE t; SET GLOBAL innodb_cmp_per_index_enabled=default; SET GLOBAL innodb_file_format=default;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
innodb-create-options.test | File | 23.34 KB | 0644 |
|
innodb-restart.test | File | 22.52 KB | 0644 |
|
innodb-wl5522-debug-zip.test | File | 19.68 KB | 0644 |
|
innodb-wl5522-zip.test | File | 13.43 KB | 0644 |
|
innodb-zip.test | File | 10.2 KB | 0644 |
|
innodb_16k.test | File | 28.95 KB | 0644 |
|
innodb_4k.test | File | 18.94 KB | 0644 |
|
innodb_8k.test | File | 20.46 KB | 0644 |
|
innodb_bug36169.test | File | 24.79 KB | 0644 |
|
innodb_bug36172.test | File | 8.11 KB | 0644 |
|
innodb_bug52745.test | File | 3.64 KB | 0644 |
|
innodb_bug53591.test | File | 705 B | 0644 |
|
innodb_bug56680.test | File | 4.38 KB | 0644 |
|
innodb_cmp_drop_table-master.opt | File | 29 B | 0644 |
|
innodb_cmp_drop_table.test | File | 1.3 KB | 0644 |
|
innodb_cmp_per_index.test | File | 2.71 KB | 0644 |
|
innodb_index_large_prefix.test | File | 14.34 KB | 0644 |
|
innodb_index_large_prefix_4k.test | File | 12.84 KB | 0644 |
|
innodb_index_large_prefix_8k.test | File | 13.89 KB | 0644 |
|
innodb_prefix_index_liftedlimit.test | File | 61.49 KB | 0644 |
|
innodb_wl6347_comp_indx_stat.test | File | 46.99 KB | 0644 |
|