File: group_min_max_notembedded.test

package info (click to toggle)
mariadb-10.5 1%3A10.5.23-0%2Bdeb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 712,240 kB
  • sloc: ansic: 2,158,658; cpp: 1,843,101; asm: 297,745; perl: 59,967; sh: 53,869; pascal: 38,348; java: 33,919; yacc: 19,639; python: 11,119; xml: 10,126; sql: 10,027; ruby: 8,544; makefile: 6,343; cs: 2,866; lex: 1,205; javascript: 1,037; objc: 80; tcl: 73; awk: 46; php: 22; sed: 16
file content (37 lines) | stat: -rw-r--r-- 1,052 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#
# Tests for group-min-max optimization that require optimizer trace
# and so need not-embedded.
#
--source include/default_optimizer_switch.inc
--source include/have_innodb.inc
--source include/have_sequence.inc
--source include/not_embedded.inc

--echo # 
--echo # MDEV-31380: Assertion `s->table->opt_range_condition_rows <= s->found_records' failed
--echo #  (assertion in 10.6+, DBL_MAX costs in 10.5)
--echo # 

CREATE TABLE t1 (a INT, b INT, PRIMARY KEY(a), KEY(b)) ENGINE=InnoDB;
INSERT INTO t1 SELECT seq, seq FROM seq_1_to_100;

SET
  @tmp=@@optimizer_use_condition_selectivity,
  optimizer_use_condition_selectivity = 1,
  @tmp2=@@optimizer_trace,
  optimizer_trace=1;

SELECT DISTINCT * FROM t1 WHERE a IN (1, 2);

select 
  CAST(json_value(json_extract(trace, '$**.chosen_access_method.cost'), '$[0]')
       as DOUBLE) < 1.0e100  as ACCESS_METHOD_COST_IS_FINITE
from information_schema.optimizer_trace;

set optimizer_use_condition_selectivity = @tmp, optimizer_trace=@tmp2;
drop table t1;

--echo #
--echo # End of 10.5 tests
--echo #