summaryrefslogtreecommitdiff
path: root/mysql-test/main/partition_mrr_innodb.test
diff options
context:
space:
mode:
authorSergei Petrunia <psergey@askmonty.org>2019-11-15 23:37:28 +0300
committerSergei Petrunia <psergey@askmonty.org>2019-11-15 23:37:28 +0300
commit86167e908fe5de6f6e9f5076b4ea8041514d0820 (patch)
tree92815b55b229fb7ce4b55eb176e2ebc19e3b8985 /mysql-test/main/partition_mrr_innodb.test
parent3d4a80153345209bad736235d4f66dcaa51a9d51 (diff)
downloadmariadb-git-86167e908fe5de6f6e9f5076b4ea8041514d0820.tar.gz
MDEV-20611: MRR scan over partitioned InnoDB table produces "Out of memory" error
Fix partitioning and DS-MRR to work together - In ha_partition::index_end(): take into account that ha_innobase (and other engines using DS-MRR) will have inited=RND when initialized for DS-MRR scan. - In ha_partition::multi_range_read_next(): if the MRR scan is using HA_MRR_NO_ASSOCIATION mode, it is not guaranteed that the partition's handler will store anything into *range_info. - In DsMrr_impl::choose_mrr_impl(): ha_partition will inquire partitions about how much memory their MRR implementation needs by passing *buffer_size=0. DS-MRR code didn't know about this (actually it used uint for buffer size calculation and would have an under-flow). Returning *buffer_size=0 made ha_partition assume that partitions do not need MRR memory and pass the same buffer to each of them. Now, this is fixed. If DS-MRR gets *buffer_size=0, it will return the amount of buffer space needed, but not more than about @@mrr_buffer_size. * Fix ha_{innobase,maria,myisam}::clone. If ha_partition uses MRR on its partitions, and partition use DS-MRR, the code will call handler->clone with TABLE (*NOT partition*) name as an argument. DS-MRR has no way of knowing the partition name, so the solution was to have the ::clone() function for the affected storage engine to ignore the name argument and get it elsewhere.
Diffstat (limited to 'mysql-test/main/partition_mrr_innodb.test')
-rw-r--r--mysql-test/main/partition_mrr_innodb.test4
1 files changed, 4 insertions, 0 deletions
diff --git a/mysql-test/main/partition_mrr_innodb.test b/mysql-test/main/partition_mrr_innodb.test
new file mode 100644
index 00000000000..1eccf070e5c
--- /dev/null
+++ b/mysql-test/main/partition_mrr_innodb.test
@@ -0,0 +1,4 @@
+--source include/have_innodb.inc
+let $engine_type= InnoDB;
+
+--source include/partition_mrr.inc