Commit 0a7d2917 authored by Monty's avatar Monty

MDEV-30328 Assertion `avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0'...

MDEV-30328 Assertion `avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0' failed in Cost_estimate::total_cost()

The assert was there to check that engines reports sensible numbers for IO.
However this does not work in case of optimizer_disk_read_ratio=0.

Fixed by removing the assert.
parent 1a13dbff
...@@ -89,3 +89,38 @@ id select_type table type possible_keys key key_len ref rows Extra ...@@ -89,3 +89,38 @@ id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 range d d 5 NULL 2 Using index condition 1 SIMPLE t1 range d d 5 NULL 2 Using index condition
Last_query_cost 0.003291 Last_query_cost 0.003291
drop table t1; drop table t1;
#
# MDEV-30328 Assertion `avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0' failed in
# Cost_estimate::total_cost()
#
set @save=@@InnoDB.optimizer_disk_read_ratio;
set global InnoDB.optimizer_disk_read_ratio=0;
create table t1 (
`l_orderkey` int(11) NOT NULL,
`l_partkey` int(11) DEFAULT NULL,
`l_suppkey` int(11) DEFAULT NULL,
`l_linenumber` int(11) NOT NULL,
`l_extra` int(11) NOT NULL,
`l_quantity` double DEFAULT NULL,
`l_extendedprice` double DEFAULT NULL,
`l_discount` double DEFAULT NULL,
`l_tax` double DEFAULT NULL,
`l_returnflag` char(1) DEFAULT NULL,
`l_linestatus` char(1) DEFAULT NULL,
`l_shipDATE` date DEFAULT NULL,
`l_commitDATE` date DEFAULT NULL,
`l_receiptDATE` date DEFAULT NULL,
`l_shipinstruct` char(25) DEFAULT NULL,
`l_shipmode` char(10) DEFAULT NULL,
`l_comment` varchar(44) DEFAULT NULL,
PRIMARY KEY (`l_orderkey`),
UNIQUE (`l_linenumber`),
UNIQUE (`l_extra`) ,
KEY `l_suppkey` (l_suppkey, l_partkey),
KEY `long_suppkey` (l_partkey, l_suppkey, l_linenumber, l_extra) )
ENGINE= InnoDB;
explain select count(*) from test.t1 force index (l_suppkey) where l_suppkey >= 0 and l_partkey >=0;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 range l_suppkey l_suppkey 10 NULL 1 Using where; Using index
drop table t1;
set global InnoDB.optimizer_disk_read_ratio=@save;
# #
# Test of cost calcuations. This test is using the Aria engine as the cost # Test of cost calculations. This test is using the Aria engine as the cost
# calculations are stable for it. # calculations are stable for it.
# #
# This file also includes MDEV's that shows errors in cost calculation functions.
#
--source include/have_sequence.inc --source include/have_sequence.inc
--source include/have_innodb.inc
create table t1 (a int primary key, b int, c int, d int, e int, key ba (b,a), key bda (b,d,a), key cba (c,b,a), key cb (c,b), key d (d)) engine=aria; create table t1 (a int primary key, b int, c int, d int, e int, key ba (b,a), key bda (b,d,a), key cba (c,b,a), key cb (c,b), key d (d)) engine=aria;
insert into t1 select seq,seq,seq,seq,seq from seq_1_to_10; insert into t1 select seq,seq,seq,seq,seq from seq_1_to_10;
...@@ -73,3 +77,40 @@ explain select a,b,e from t1 where d=10 or d=11; ...@@ -73,3 +77,40 @@ explain select a,b,e from t1 where d=10 or d=11;
--source include/last_query_cost.inc --source include/last_query_cost.inc
drop table t1; drop table t1;
--echo #
--echo # MDEV-30328 Assertion `avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0' failed in
--echo # Cost_estimate::total_cost()
--echo #
set @save=@@InnoDB.optimizer_disk_read_ratio;
set global InnoDB.optimizer_disk_read_ratio=0;
create table t1 (
`l_orderkey` int(11) NOT NULL,
`l_partkey` int(11) DEFAULT NULL,
`l_suppkey` int(11) DEFAULT NULL,
`l_linenumber` int(11) NOT NULL,
`l_extra` int(11) NOT NULL,
`l_quantity` double DEFAULT NULL,
`l_extendedprice` double DEFAULT NULL,
`l_discount` double DEFAULT NULL,
`l_tax` double DEFAULT NULL,
`l_returnflag` char(1) DEFAULT NULL,
`l_linestatus` char(1) DEFAULT NULL,
`l_shipDATE` date DEFAULT NULL,
`l_commitDATE` date DEFAULT NULL,
`l_receiptDATE` date DEFAULT NULL,
`l_shipinstruct` char(25) DEFAULT NULL,
`l_shipmode` char(10) DEFAULT NULL,
`l_comment` varchar(44) DEFAULT NULL,
PRIMARY KEY (`l_orderkey`),
UNIQUE (`l_linenumber`),
UNIQUE (`l_extra`) ,
KEY `l_suppkey` (l_suppkey, l_partkey),
KEY `long_suppkey` (l_partkey, l_suppkey, l_linenumber, l_extra) )
ENGINE= InnoDB;
explain select count(*) from test.t1 force index (l_suppkey) where l_suppkey >= 0 and l_partkey >=0;
drop table t1;
set global InnoDB.optimizer_disk_read_ratio=@save;
...@@ -2834,7 +2834,6 @@ class Cost_estimate ...@@ -2834,7 +2834,6 @@ class Cost_estimate
double total_cost() const double total_cost() const
{ {
DBUG_ASSERT(avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0);
return ((index_cost.io + row_cost.io) * avg_io_cost+ return ((index_cost.io + row_cost.io) * avg_io_cost+
index_cost.cpu + row_cost.cpu + comp_cost + copy_cost + index_cost.cpu + row_cost.cpu + comp_cost + copy_cost +
cpu_cost); cpu_cost);
...@@ -2843,7 +2842,6 @@ class Cost_estimate ...@@ -2843,7 +2842,6 @@ class Cost_estimate
/* Cost for just fetching and copying a row (no compare costs) */ /* Cost for just fetching and copying a row (no compare costs) */
double fetch_cost() const double fetch_cost() const
{ {
DBUG_ASSERT(avg_io_cost != 0.0 || index_cost.io + row_cost.io == 0);
return ((index_cost.io + row_cost.io) * avg_io_cost+ return ((index_cost.io + row_cost.io) * avg_io_cost+
index_cost.cpu + row_cost.cpu + copy_cost); index_cost.cpu + row_cost.cpu + copy_cost);
} }
...@@ -2875,7 +2873,6 @@ class Cost_estimate ...@@ -2875,7 +2873,6 @@ class Cost_estimate
void add(Cost_estimate *cost) void add(Cost_estimate *cost)
{ {
DBUG_ASSERT(cost->avg_io_cost != 0.0 || (index_cost.io + row_cost.io == 0));
avg_io_cost= cost->avg_io_cost; avg_io_cost= cost->avg_io_cost;
index_cost.io+= cost->index_cost.io; index_cost.io+= cost->index_cost.io;
index_cost.cpu+= cost->index_cost.cpu; index_cost.cpu+= cost->index_cost.cpu;
......
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