Files
tidb/tests/integrationtest/t/executor/split_table.test

144 lines
4.6 KiB
Plaintext

# TestSplitRegionEdgeCase
drop table if exists t;
create table t(a bigint(20) auto_increment primary key);
split table t between (-9223372036854775808) and (9223372036854775807) regions 16;
drop table if exists t;
create table t(a int(20) auto_increment primary key);
-- error 1690
split table t between (-9223372036854775808) and (9223372036854775807) regions 16;
drop table if exists t;
# TestSplitTableRegion
drop table if exists t, t1;
create table t(a varchar(100),b int, index idx1(b,a));
split table t index idx1 by (10000,"abcd"),(10000000);
-- error 1265
split table t index idx1 by ("abcd");
## Test for split index region.
## Check min value is more than max value.
split table t index idx1 between (0) and (1000000000) regions 10;
-- error 8212
split table t index idx1 between (2,'a') and (1,'c') regions 10;
## Check min value is invalid.
-- error 1105
split table t index idx1 between () and (1) regions 10;
## Check max value is invalid.
-- error 1105
split table t index idx1 between (1) and () regions 10;
## Check pre-split region num is too large.
-- error 1105
split table t index idx1 between (0) and (1000000000) regions 10000;
## Check pre-split region num 0 is invalid.
-- error 1105
split table t index idx1 between (0) and (1000000000) regions 0;
## Test truncate error msg.
-- error 1265
split table t index idx1 between ("aa") and (1000000000) regions 0;
## Test for split table region.
split table t between (0) and (1000000000) regions 10;
## Check the lower value is more than the upper value.
-- error 8212
split table t between (2) and (1) regions 10;
## Check the lower value is invalid.
-- error 1105
split table t between () and (1) regions 10;
## Check upper value is invalid.
-- error 1105
split table t between (1) and () regions 10;
## Check pre-split region num is too large.
-- error 1105
split table t between (0) and (1000000000) regions 10000;
## Check pre-split region num 0 is invalid.
-- error 1105
split table t between (0) and (1000000000) regions 0;
## Test truncate error msg.
-- error 1265
split table t between ("aa") and (1000000000) regions 10;
## Test split table region step is too small.
-- error 8212
split table t between (0) and (100) regions 10;
## Test split region by syntax.
split table t by (0),(1000),(1000000);
## Test split region twice to test for multiple batch split region requests.
create table t1(a int, b int);
split table t1 between(0) and (10000) regions 10;
split table t1 between(10) and (10010) regions 5;
## Test split region for partition table.
drop table if exists t;
create table t (a int,b int) partition by hash(a) partitions 5;
split table t between (0) and (1000000) regions 5;
## Test for `split for region` syntax.
split region for partition table t between (1000000) and (100000000) regions 10;
## Test split region for partition table with specified partition.
split table t partition (p1,p2) between (100000000) and (1000000000) regions 5;
## Test for `split for region` syntax.
split region for partition table t partition (p3,p4) between (100000000) and (1000000000) regions 5;
# TestClusterIndexSplitTableIntegration
set tidb_enable_clustered_index=ON;
drop table if exists t;
create table t (a varchar(255), b double, c int, primary key (a, b));
## Value list length not match.
-- error 1105
split table t between ('aaa') and ('aaa', 100.0) regions 10;
-- error 1105
split table t between ('aaa', 1.0) and ('aaa', 100.0, 11) regions 10;
## Value type not match.
-- error 1265
split table t between ('aaa', 0.0) and (100.0, 'aaa') regions 10;
## lower bound >= upper bound.
-- error 8212
split table t between ('aaa', 0.0) and ('aaa', 0.0) regions 10;
-- error 8212
split table t between ('bbb', 0.0) and ('aaa', 0.0) regions 10;
## Exceed limit 1000.
-- error 1105
split table t between ('aaa', 0.0) and ('aaa', 0.1) regions 100000;
## Split on null values.
-- error 1048
split table t between (null, null) and (null, null) regions 1000;
-- error 1048
split table t by (null, null);
## Success.
split table t between ('aaa', 0.0) and ('aaa', 100.0) regions 10;
split table t by ('aaa', 0.0), ('aaa', 20.0), ('aaa', 100.0);
split table t by ('aaa', 100.0), ('qqq', 20.0), ('zzz', 100.0), ('zzz', 1000.0);
drop table t;
create table t (a int, b int, c int, d int, primary key(d, a, c));
split table t by (0, 0, 0), (1, 2, 3), (65535, 65535, 65535);
drop table if exists t;
create table t (a varchar(255), b decimal, c int, primary key (a, b));
-- error 1265
split table t by ('aaa', '');
drop table t;
CREATE TABLE t (`id` varchar(10) NOT NULL, primary key (`id`) CLUSTERED);
-- error 1176
split table t index `primary` between (0) and (1000) regions 2;
set tidb_enable_clustered_index=default;