1-- source include/have_innodb.inc
2
3let MYSQLD_DATADIR =`SELECT @@datadir`;
4
5# Export/import on the same instance, with --innodb-file-per-table=1
6CREATE DATABASE testdb_wl5522;
7
8CREATE TABLE testdb_wl5522.t1(col1 bit(1) , col2 boolean,col3 tinyint , col4 smallint , col5 mediumint ,col6 int , col7 bigint , col8 float (14,3) ,col9 double (14,3), col10 VARCHAR(20) CHARACTER SET utf8 , col11 TEXT CHARACTER SET binary ,      col12 ENUM('a','b','c') CHARACTER SET binary  ,col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,col14 CHAR(20) , col15 VARBINARY (400) , col16 BINARY(40), col17 BLOB (400) , col18 int not null primary key,col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,col22 TIME , col23 YEAR ) ENGINE = Innodb;
9
10
11CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
12CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
13CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
14CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
15
16INSERT INTO testdb_wl5522.t1 VALUES (1,1,-128,32767,-8388608,2147483647,-9223372036854775808, 92233720368.222,-92233720368.222,'aaa', 'aaaaaaaaaa','b','bbbbb','ccccc',REPEAT('d',40),REPEAT('d',40),REPEAT('d',40), 1,'1000-01-01','3000-12-31 23:59:59.99','1990-01-01 00:00:01.00','01:59:59.00','1901');
17
18INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,NULL,NULL,NULL,NULL);
19
20--error ER_BAD_NULL_ERROR
21INSERT INTO  testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);
22
23--error ER_DUP_ENTRY
24INSERT INTO  testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,NULL,NULL,NULL,NULL);
25
26FLUSH TABLES testdb_wl5522.t1 WITH READ LOCK;
27SELECT COUNT(*) FROM testdb_wl5522.t1;
28perl;
29do "$ENV{MTR_SUITE_DIR}/include/innodb-util.pl";
30ib_backup_tablespaces("testdb_wl5522", "t1");
31EOF
32UNLOCK TABLES;
33
34DROP TABLE testdb_wl5522.t1;
35
36CREATE TABLE testdb_wl5522.t1(col1 bit(1) , col2 boolean,col3 tinyint , col4 smallint , col5 mediumint ,col6 int , col7 bigint , col8 float (14,3) ,col9 double (14,3), col10 VARCHAR(20) CHARACTER SET utf8 , col11 TEXT CHARACTER SET binary ,      col12 ENUM('a','b','c') CHARACTER SET binary  ,col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,col14 CHAR(20) , col15 VARBINARY (400) , col16 BINARY(40), col17 BLOB (400) , col18 int not null primary key,col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,col22 TIME , col23 YEAR ) ENGINE = Innodb;
37
38
39CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
40CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
41CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
42CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
43
44ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
45
46perl;
47do "$ENV{MTR_SUITE_DIR}/include/innodb-util.pl";
48ib_restore_tablespaces("testdb_wl5522", "t1");
49EOF
50
51ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
52
53CHECK TABLE testdb_wl5522.t1;
54
55SELECT COUNT(*) FROM testdb_wl5522.t1;
56
57DROP TABLE testdb_wl5522.t1;
58
59DROP DATABASE testdb_wl5522;
60