Merge 10.1 into 10.2
This commit is contained in:
commit
44c5144943
8
debian/mariadb-server-10.2.postinst
vendored
8
debian/mariadb-server-10.2.postinst
vendored
@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
. /usr/share/debconf/confmodule
|
. /usr/share/debconf/confmodule
|
||||||
|
|
||||||
# assume the filename is /path/to/mariadb-server-##.#.postinst
|
# Automatically set version to ease maintenance of this file
|
||||||
VER=${0: -13:4}
|
MAJOR_VER="${DPKG_MAINTSCRIPT_PACKAGE#mariadb-server-}"
|
||||||
|
|
||||||
if [ -n "$DEBIAN_SCRIPT_DEBUG" ]; then set -v -x; DEBIAN_SCRIPT_TRACE=1; fi
|
if [ -n "$DEBIAN_SCRIPT_DEBUG" ]; then set -v -x; DEBIAN_SCRIPT_TRACE=1; fi
|
||||||
${DEBIAN_SCRIPT_TRACE:+ echo "#42#DEBUG# RUNNING $0 $*" 1>&2 }
|
${DEBIAN_SCRIPT_TRACE:+ echo "#42#DEBUG# RUNNING $0 $*" 1>&2 }
|
||||||
@ -11,7 +11,7 @@ ${DEBIAN_SCRIPT_TRACE:+ echo "#42#DEBUG# RUNNING $0 $*" 1>&2 }
|
|||||||
export PATH=$PATH:/sbin:/usr/sbin:/bin:/usr/bin
|
export PATH=$PATH:/sbin:/usr/sbin:/bin:/usr/bin
|
||||||
|
|
||||||
# This command can be used as pipe to syslog. With "-s" it also logs to stderr.
|
# This command can be used as pipe to syslog. With "-s" it also logs to stderr.
|
||||||
ERR_LOGGER="logger -p daemon.err -t mariadb-server-$VER.postinst -i"
|
ERR_LOGGER="logger -p daemon.err -t mariadb-server-$MAJOR_VER.postinst -i"
|
||||||
# This will make an error in a logged command immediately apparent by aborting
|
# This will make an error in a logged command immediately apparent by aborting
|
||||||
# the install, rather than failing silently and leaving a broken install.
|
# the install, rather than failing silently and leaving a broken install.
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
@ -149,7 +149,7 @@ EOF
|
|||||||
|
|
||||||
|
|
||||||
# To avoid downgrades.
|
# To avoid downgrades.
|
||||||
touch $mysql_statedir/debian-$VER.flag
|
touch $mysql_statedir/debian-$MAJOR_VER.flag
|
||||||
|
|
||||||
## On every reconfiguration the maintenance user is recreated.
|
## On every reconfiguration the maintenance user is recreated.
|
||||||
#
|
#
|
||||||
|
@ -2119,12 +2119,12 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
1 SIMPLE t1 index NULL idx_t1_2 147 NULL 128 Using index
|
1 SIMPLE t1 index NULL idx_t1_2 147 NULL 128 Using index
|
||||||
explain extended select a1,a2,count(a2) from t1 where (a1 > 'a') group by a1,a2,b;
|
explain extended select a1,a2,count(a2) from t1 where (a1 > 'a') group by a1,a2,b;
|
||||||
id select_type table type possible_keys key key_len ref rows filtered Extra
|
id select_type table type possible_keys key key_len ref rows filtered Extra
|
||||||
1 SIMPLE t1 index idx_t1_0,idx_t1_1,idx_t1_2 idx_t1_2 147 NULL 128 75.00 Using where; Using index
|
1 SIMPLE t1 range idx_t1_0,idx_t1_1,idx_t1_2 idx_t1_2 65 NULL 102 94.12 Using where; Using index
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1003 select `test`.`t1`.`a1` AS `a1`,`test`.`t1`.`a2` AS `a2`,count(`test`.`t1`.`a2`) AS `count(a2)` from `test`.`t1` where `test`.`t1`.`a1` > 'a' group by `test`.`t1`.`a1`,`test`.`t1`.`a2`,`test`.`t1`.`b`
|
Note 1003 select `test`.`t1`.`a1` AS `a1`,`test`.`t1`.`a2` AS `a2`,count(`test`.`t1`.`a2`) AS `count(a2)` from `test`.`t1` where `test`.`t1`.`a1` > 'a' group by `test`.`t1`.`a1`,`test`.`t1`.`a2`,`test`.`t1`.`b`
|
||||||
explain extended select sum(ord(a1)) from t1 where (a1 > 'a') group by a1,a2,b;
|
explain extended select sum(ord(a1)) from t1 where (a1 > 'a') group by a1,a2,b;
|
||||||
id select_type table type possible_keys key key_len ref rows filtered Extra
|
id select_type table type possible_keys key key_len ref rows filtered Extra
|
||||||
1 SIMPLE t1 index idx_t1_0,idx_t1_1,idx_t1_2 idx_t1_2 147 NULL 128 75.00 Using where; Using index
|
1 SIMPLE t1 range idx_t1_0,idx_t1_1,idx_t1_2 idx_t1_2 65 NULL 102 94.12 Using where; Using index
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1003 select sum(ord(`test`.`t1`.`a1`)) AS `sum(ord(a1))` from `test`.`t1` where `test`.`t1`.`a1` > 'a' group by `test`.`t1`.`a1`,`test`.`t1`.`a2`,`test`.`t1`.`b`
|
Note 1003 select sum(ord(`test`.`t1`.`a1`)) AS `sum(ord(a1))` from `test`.`t1` where `test`.`t1`.`a1` > 'a' group by `test`.`t1`.`a1`,`test`.`t1`.`a2`,`test`.`t1`.`b`
|
||||||
create table t4 as select distinct a1, a2, b, c from t1;
|
create table t4 as select distinct a1, a2, b, c from t1;
|
||||||
|
@ -49,6 +49,32 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
1 SIMPLE t1 index_merge key1,key2 key1,key2 5,5 NULL # Using sort_union(key1,key2); Using where
|
1 SIMPLE t1 index_merge key1,key2 key1,key2 5,5 NULL # Using sort_union(key1,key2); Using where
|
||||||
drop table t0, t1;
|
drop table t0, t1;
|
||||||
#
|
#
|
||||||
|
# MDEV-18094: Query with order by limit picking index scan over filesort
|
||||||
|
#
|
||||||
|
create table t0 (a int);
|
||||||
|
INSERT INTO t0 VALUES (0),(0),(0),(0),(2),(0),(0),(1),(1),(0);
|
||||||
|
CREATE TABLE t1 (
|
||||||
|
a int(11),
|
||||||
|
b int(11),
|
||||||
|
c int(11),
|
||||||
|
KEY a_c (a,c),
|
||||||
|
KEY a_b (a,b)
|
||||||
|
) ENGINE=InnoDB;
|
||||||
|
insert into t1 select A.a , B.a, C.a from t0 A, t0 B, t0 C;
|
||||||
|
# should use ref access
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ref a_c,a_b a_c 10 const,const 20 Using where; Using filesort
|
||||||
|
# both should use range access
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b limit 1000;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 range a_c,a_b a_b 5 NULL 200 Using where
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b limit 2000;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 range a_c,a_b a_b 5 NULL 200 Using where
|
||||||
|
drop table t1,t0;
|
||||||
|
# Start of 10.2 tests
|
||||||
|
#
|
||||||
# MDEV-14071: wrong results with orderby_uses_equalities=on
|
# MDEV-14071: wrong results with orderby_uses_equalities=on
|
||||||
# (duplicate of MDEV-13994)
|
# (duplicate of MDEV-13994)
|
||||||
#
|
#
|
||||||
@ -121,3 +147,4 @@ i n
|
|||||||
656 eight
|
656 eight
|
||||||
set optimizer_switch= @save_optimizer_switch;
|
set optimizer_switch= @save_optimizer_switch;
|
||||||
DROP TABLE t1,t2,t3;
|
DROP TABLE t1,t2,t3;
|
||||||
|
# End of 10.2 tests
|
||||||
|
@ -167,7 +167,7 @@ WHERE ts BETWEEN '0000-00-00' AND '2010-00-01 00:00:00'
|
|||||||
ORDER BY ts DESC
|
ORDER BY ts DESC
|
||||||
LIMIT 2;
|
LIMIT 2;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t1 index PRIMARY PRIMARY 4 NULL 2 Using where
|
1 SIMPLE t1 range PRIMARY PRIMARY 4 NULL 4 Using where
|
||||||
|
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
#
|
#
|
||||||
|
@ -62,6 +62,32 @@ where key1<3 or key2<3;
|
|||||||
|
|
||||||
drop table t0, t1;
|
drop table t0, t1;
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # MDEV-18094: Query with order by limit picking index scan over filesort
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
create table t0 (a int);
|
||||||
|
INSERT INTO t0 VALUES (0),(0),(0),(0),(2),(0),(0),(1),(1),(0);
|
||||||
|
|
||||||
|
CREATE TABLE t1 (
|
||||||
|
a int(11),
|
||||||
|
b int(11),
|
||||||
|
c int(11),
|
||||||
|
KEY a_c (a,c),
|
||||||
|
KEY a_b (a,b)
|
||||||
|
) ENGINE=InnoDB;
|
||||||
|
insert into t1 select A.a , B.a, C.a from t0 A, t0 B, t0 C;
|
||||||
|
|
||||||
|
--echo # should use ref access
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b;
|
||||||
|
|
||||||
|
--echo # both should use range access
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b limit 1000;
|
||||||
|
explain select a,b,c from t1 where a=1 and c=2 order by b limit 2000;
|
||||||
|
drop table t1,t0;
|
||||||
|
|
||||||
|
--echo # Start of 10.2 tests
|
||||||
|
|
||||||
--echo #
|
--echo #
|
||||||
--echo # MDEV-14071: wrong results with orderby_uses_equalities=on
|
--echo # MDEV-14071: wrong results with orderby_uses_equalities=on
|
||||||
--echo # (duplicate of MDEV-13994)
|
--echo # (duplicate of MDEV-13994)
|
||||||
@ -108,3 +134,5 @@ eval $q2;
|
|||||||
set optimizer_switch= @save_optimizer_switch;
|
set optimizer_switch= @save_optimizer_switch;
|
||||||
|
|
||||||
DROP TABLE t1,t2,t3;
|
DROP TABLE t1,t2,t3;
|
||||||
|
|
||||||
|
--echo # End of 10.2 tests
|
||||||
|
@ -958,7 +958,13 @@ do
|
|||||||
cmd="$cmd "`shell_quote_string "$i"`
|
cmd="$cmd "`shell_quote_string "$i"`
|
||||||
done
|
done
|
||||||
cmd="$cmd $args"
|
cmd="$cmd $args"
|
||||||
[ $dry_run -eq 1 ] && return
|
|
||||||
|
if [ $dry_run -eq 1 ]
|
||||||
|
then
|
||||||
|
# RETURN or EXIT depending if the script is being sourced or not.
|
||||||
|
(return 2> /dev/null) && return || exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
# Avoid 'nohup: ignoring input' warning
|
# Avoid 'nohup: ignoring input' warning
|
||||||
test -n "$NOHUP_NICENESS" && cmd="$cmd < /dev/null"
|
test -n "$NOHUP_NICENESS" && cmd="$cmd < /dev/null"
|
||||||
|
@ -2408,12 +2408,16 @@ int SQL_SELECT::test_quick_select(THD *thd, key_map keys_to_use,
|
|||||||
records= head->stat_records();
|
records= head->stat_records();
|
||||||
if (!records)
|
if (!records)
|
||||||
records++; /* purecov: inspected */
|
records++; /* purecov: inspected */
|
||||||
|
|
||||||
|
if (head->force_index || force_quick_range)
|
||||||
|
scan_time= read_time= DBL_MAX;
|
||||||
|
else
|
||||||
|
{
|
||||||
scan_time= (double) records / TIME_FOR_COMPARE + 1;
|
scan_time= (double) records / TIME_FOR_COMPARE + 1;
|
||||||
read_time= (double) head->file->scan_time() + scan_time + 1.1;
|
read_time= (double) head->file->scan_time() + scan_time + 1.1;
|
||||||
if (head->force_index)
|
|
||||||
scan_time= read_time= DBL_MAX;
|
|
||||||
if (limit < records)
|
if (limit < records)
|
||||||
read_time= (double) records + scan_time + 1; // Force to use index
|
read_time= (double) records + scan_time + 1; // Force to use index
|
||||||
|
}
|
||||||
|
|
||||||
possible_keys.clear_all();
|
possible_keys.clear_all();
|
||||||
|
|
||||||
|
@ -6,5 +6,5 @@ create table t2970 (a int, b int, c int, d int, key(a), key(a,b));
|
|||||||
insert into t2970 values (1,1,1,1),(1,2,3,4);
|
insert into t2970 values (1,1,1,1),(1,2,3,4);
|
||||||
explain select a,count(b),max(b) from t2970 where a > 0 group by a order by a;
|
explain select a,count(b),max(b) from t2970 where a > 0 group by a order by a;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t2970 index a,a_2 a_2 10 NULL 2 Using where; Using index
|
1 SIMPLE t2970 range a,a_2 a_2 5 NULL 2 Using where; Using index
|
||||||
drop table t2970;
|
drop table t2970;
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
# (at your option) any later version.
|
# (at your option) any later version.
|
||||||
|
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=MariaDB @VERSION@ database server (multi-instance)
|
Description=MariaDB @VERSION@ database server (multi-instance %I)
|
||||||
Documentation=man:mysqld(8)
|
Documentation=man:mysqld(8)
|
||||||
Documentation=https://mariadb.com/kb/en/library/systemd/
|
Documentation=https://mariadb.com/kb/en/library/systemd/
|
||||||
After=network.target
|
After=network.target
|
||||||
|
Loading…
x
Reference in New Issue
Block a user