mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 04:22:27 +01:00
a03c9ff55f
The original XtraDB (and InnoDB plugin) is shipped as a separate source tree which is copied into the MySQL source, after which a setup.sh script must be run to move things into place. Now that XtraDB is part of the MariaDB source tree, this commit fixes these things up once and for all: - New innodb build scripts. - Test suite fixes (new tests and patches to existing). - Remove files no longer needed due to this.
116 lines
2.7 KiB
Text
116 lines
2.7 KiB
Text
create table t1(a int not null, b int, c char(10), d varchar(20), primary key (a)) engine = innodb default charset=ucs2;
|
|
insert into t1 values (1,1,'ab','ab'),(2,2,'ac','ac'),(3,2,'ad','ad'),(4,4,'afe','afe');
|
|
commit;
|
|
alter table t1 add unique index (b);
|
|
ERROR 23000: Duplicate entry '2' for key 'b'
|
|
insert into t1 values(8,9,'fff','fff');
|
|
select * from t1;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) NOT NULL,
|
|
`b` int(11) DEFAULT NULL,
|
|
`c` char(10) DEFAULT NULL,
|
|
`d` varchar(20) DEFAULT NULL,
|
|
PRIMARY KEY (`a`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=ucs2
|
|
alter table t1 add index (b);
|
|
insert into t1 values(10,10,'kkk','iii');
|
|
select * from t1;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
select * from t1 force index(b) order by b;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
explain select * from t1 force index(b) order by b;
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 index NULL b 5 NULL 6
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) NOT NULL,
|
|
`b` int(11) DEFAULT NULL,
|
|
`c` char(10) DEFAULT NULL,
|
|
`d` varchar(20) DEFAULT NULL,
|
|
PRIMARY KEY (`a`),
|
|
KEY `b` (`b`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=ucs2
|
|
alter table t1 add unique index (c), add index (d);
|
|
insert into t1 values(11,11,'aaa','mmm');
|
|
select * from t1;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
11 11 aaa mmm
|
|
select * from t1 force index(b) order by b;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
11 11 aaa mmm
|
|
select * from t1 force index(c) order by c;
|
|
a b c d
|
|
11 11 aaa mmm
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
select * from t1 force index(d) order by d;
|
|
a b c d
|
|
1 1 ab ab
|
|
2 2 ac ac
|
|
3 2 ad ad
|
|
4 4 afe afe
|
|
8 9 fff fff
|
|
10 10 kkk iii
|
|
11 11 aaa mmm
|
|
explain select * from t1 force index(b) order by b;
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 index NULL b 5 NULL 7
|
|
explain select * from t1 force index(c) order by c;
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 index NULL c 21 NULL 7
|
|
explain select * from t1 force index(d) order by d;
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 index NULL d 43 NULL 7
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) NOT NULL,
|
|
`b` int(11) DEFAULT NULL,
|
|
`c` char(10) DEFAULT NULL,
|
|
`d` varchar(20) DEFAULT NULL,
|
|
PRIMARY KEY (`a`),
|
|
UNIQUE KEY `c` (`c`),
|
|
KEY `b` (`b`),
|
|
KEY `d` (`d`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=ucs2
|
|
check table t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 check status OK
|
|
drop table t1;
|