mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 21:12:26 +01:00
d929342b0f
Syntax. Server support. Test cases. InnoDB bugfixes: * don't mess around with system sprintf's, always use my_error() for errors. * don't use InnoDB internal error codes where OS error codes are expected. * don't say "file not found", when it was.
73 lines
3.4 KiB
Text
73 lines
3.4 KiB
Text
-- source include/have_innodb.inc
|
|
--disable_warnings
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
--enable_warnings
|
|
let MYSQLD_DATADIR =`SELECT @@datadir`;
|
|
let $innodb_file_per_table = `SELECT @@innodb_file_per_table`;
|
|
let $innodb_file_format = `SELECT @@innodb_file_format`;
|
|
|
|
SET GLOBAL innodb_file_per_table = 1;
|
|
SELECT @@innodb_file_per_table;
|
|
|
|
#SET GLOBAL innodb_file_format = `Barracuda`;
|
|
#SELECT @@innodb_file_format;
|
|
|
|
# Export/import on the same instance, with --innodb-file-per-table=1
|
|
CREATE DATABASE testdb_wl5522;
|
|
|
|
CREATE 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;
|
|
|
|
|
|
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
|
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
|
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
|
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
|
|
|
INSERT 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');
|
|
|
|
INSERT 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);
|
|
|
|
--error ER_BAD_NULL_ERROR
|
|
INSERT 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);
|
|
|
|
--error ER_DUP_ENTRY
|
|
INSERT 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);
|
|
|
|
FLUSH TABLES testdb_wl5522.t1 WITH READ LOCK;
|
|
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
|
perl;
|
|
do "$ENV{MTR_SUITE_DIR}/include/innodb-util.pl";
|
|
ib_backup_tablespaces("testdb_wl5522", "t1");
|
|
EOF
|
|
UNLOCK TABLES;
|
|
|
|
DROP TABLE testdb_wl5522.t1;
|
|
|
|
CREATE 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;
|
|
|
|
|
|
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
|
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
|
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
|
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
|
|
|
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
|
|
|
perl;
|
|
do "$ENV{MTR_SUITE_DIR}/include/innodb-util.pl";
|
|
ib_restore_tablespaces("testdb_wl5522", "t1");
|
|
EOF
|
|
|
|
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
|
|
|
CHECK TABLE testdb_wl5522.t1;
|
|
|
|
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
|
|
|
DROP TABLE testdb_wl5522.t1;
|
|
|
|
DROP DATABASE testdb_wl5522;
|
|
|
|
eval SET GLOBAL INNODB_FILE_FORMAT=$innodb_file_format;
|
|
eval SET GLOBAL INNODB_FILE_PER_TABLE=$innodb_file_per_table;
|