Current Path : /home/usr.opt/mysql57/mysql-test/r/ |
FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64 |
Current File : //home/usr.opt/mysql57/mysql-test/r/ignore_strict.result |
# # Part 1 : Statements with IGNORE to convert Errors to Warnings. # SET @org_mode=@@sql_mode; # #For Error Code : ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET # CREATE TABLE t1 (a int) ENGINE = InnoDB PARTITION BY HASH (a) PARTITIONS 2; INSERT INTO t1 VALUES (0), (1), (2), (3); CREATE VIEW v1 AS SELECT a FROM t1 PARTITION (p0); SELECT * FROM t1; a 0 2 1 3 SELECT * FROM v1; a 0 2 INSERT INTO v1 VALUES (10),(11); ERROR HY000: Found a row not matching the given partition set INSERT IGNORE INTO v1 VALUES (10),(11); Warnings: Warning 1748 Found a row not matching the given partition set UPDATE IGNORE v1 SET a=11 WHERE a=2; Warnings: Warning 1748 Found a row not matching the given partition set SELECT * FROM v1; a 0 2 10 SELECT * from t1; a 0 2 10 1 3 DROP TABLE t1; DROP VIEW v1; # #For Error Code : ER_NO_PARTITION_FOR_GIVEN_VALUE # ER_NO_PARTITION_FOR_GIVEN_VALUE_SILENT # CREATE TABLE t1 (a int) ENGINE = InnoDB PARTITION BY LIST (a) (PARTITION x1 VALUES IN (2,5), PARTITION x2 VALUES IN (3)); INSERT INTO t1 VALUES (2), (3), (5); INSERT INTO t1 VALUES (2),(4); ERROR HY000: Table has no partition for value 4 INSERT IGNORE INTO t1 VALUES (2),(4); Warnings: Warning 1526 Table has no partition for value 4 SELECT * FROM t1; a 2 5 2 3 UPDATE t1 SET a=a+1; ERROR HY000: Table has no partition for value 6 UPDATE IGNORE t1 SET a=a+1; Warnings: Warning 1526 Table has no partition for value 6 Warning 1526 Table has no partition for value 4 SELECT * FROM t1; a 5 3 3 3 DROP TABLE t1; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY, FOREIGN KEY(c) REFERENCES t2(b)) ENGINE = InnoDB; INSERT INTO t1 VALUES (1), (2), (5); INSERT INTO t2 VALUES (1); INSERT INTO t3 VALUES (1), (2); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) INSERT IGNORE INTO t3 VALUES (1), (2); Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE t3 SET c=2 where c=1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t3 SET c=2 where c=1; Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) DELETE FROM t1; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) DELETE IGNORE FROM t1; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) SELECT * FROM t1; a 1 UPDATE t2 SET b=b+5; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t2 SET b=b+5; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) SELECT * FROM t2; b 1 DROP TABLE t3,t2,t1; CREATE TABLE t1 (a INT) ENGINE = InnoDB; INSERT INTO t1 VALUES (1),(NULL),(2); SET sql_mode = 'NO_ENGINE_SUBSTITUTION'; Warnings: Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. ALTER TABLE t1 CHANGE a a INT NOT NULL; Warnings: Warning 1265 Data truncated for column 'a' at row 2 SET sql_mode = default; SELECT * FROM t1; a 1 0 2 UPDATE IGNORE t1 SET a=NULL WHERE a=0; Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 1 0 2 DELETE FROM t1; INSERT INTO t1 VALUES (NULL); ERROR 23000: Column 'a' cannot be null INSERT IGNORE INTO t1 VALUES (NULL); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 INSERT IGNORE INTO t1 VALUES (NULL),(3); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 0 3 DROP TABLE t1; CREATE TABLE t1(a INT, b INT) ENGINE = InnoDB; CREATE TABLE t2(a INT, b INT NOT NULL) ENGINE = InnoDB; INSERT INTO t1 VALUES(1, NULL),(2,NULL); INSERT INTO t2 VALUES (1,3), (2,4); UPDATE IGNORE t1,t2 SET t2.b=NULL; Warnings: Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null DROP TABLE t1,t2; # # IGNORE keyword in the statement should not affect the errors in the # trigger execution if trigger statement does not have IGNORE keyword. # and vice versa. # CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT PRIMARY KEY, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY) ENGINE = InnoDB; INSERT INTO t1 VALUES (1), (2); INSERT INTO t2 VALUES (1); INSERT INTO t3 VALUES (1),(2),(3),(4),(5); CREATE TRIGGER post_insert_t1 AFTER INSERT ON t1 FOR EACH ROW BEGIN INSERT INTO t3 VALUES(5); END| CREATE TRIGGER post_update_t1 AFTER UPDATE ON t1 FOR EACH ROW BEGIN INSERT INTO t3 VALUES(4); END| INSERT IGNORE INTO t1 VALUES(3); ERROR 23000: Duplicate entry '5' for key 'PRIMARY' SELECT * FROM t1; a 1 2 UPDATE IGNORE t1 SET a=3 WHERE a=2; ERROR 23000: Duplicate entry '4' for key 'PRIMARY' SELECT * FROM t1; a 1 2 DROP TRIGGER post_insert_t1; DROP TRIGGER post_update_t1; CREATE TRIGGER post_insert_t1 AFTER INSERT ON t1 FOR EACH ROW BEGIN INSERT IGNORE INTO t3 VALUES (5),(6); END| CREATE TRIGGER post_update_t1 AFTER UPDATE ON t1 FOR EACH ROW BEGIN INSERT IGNORE INTO t3 VALUES(4); END| INSERT INTO t1 VALUES(2); ERROR 23000: Duplicate entry '2' for key 'PRIMARY' SELECT * FROM t3; c 1 2 3 4 5 INSERT IGNORE INTO t1 VALUES(2),(3); Warnings: Warning 1062 Duplicate entry '2' for key 'PRIMARY' SELECT * FROM t1; a 1 2 3 SELECT * FROM t3; c 1 2 3 4 5 6 UPDATE IGNORE t1 SET a=3 WHERE a=2; Warnings: Warning 1062 Duplicate entry '3' for key 'PRIMARY' DROP TRIGGER post_insert_t1; DROP TRIGGER post_update_t1; DROP TABLE t2,t1,t3; # # Part 2 : Statements with IGNORE + STRICT # These statements gives error by default # without IGNORE and STRICT mode. # SET sql_mode=default; CREATE TABLE t1 (a INT) ENGINE = InnoDB; INSERT INTO t1 VALUES (1),(NULL),(2); DROP TABLE t1; CREATE TABLE t1(a INT NOT NULL) ENGINE = InnoDB; INSERT INTO t1 VALUES (NULL); ERROR 23000: Column 'a' cannot be null INSERT IGNORE INTO t1 VALUES(NULL); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 INSERT INTO t1 VALUES (NULL),(3); ERROR 23000: Column 'a' cannot be null INSERT IGNORE INTO t1 VALUES (NULL),(1); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 0 1 UPDATE t1 SET a=NULL WHERE a=0; ERROR 23000: Column 'a' cannot be null UPDATE IGNORE t1 SET a=NULL WHERE a=0; Warnings: Warning 1048 Column 'a' cannot be null Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 0 1 DROP TABLE t1; CREATE TABLE t1(a INT, b INT) ENGINE = InnoDB; CREATE TABLE t2(a INT, b INT NOT NULL) ENGINE = InnoDB; INSERT INTO t1 VALUES(1, NULL),(2,NULL); INSERT INTO t2 VALUES (1,3), (2,4); UPDATE t1,t2 SET t2.b=NULL; ERROR 23000: Column 'b' cannot be null UPDATE IGNORE t1,t2 SET t2.b=NULL; Warnings: Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null DROP TABLE t1, t2; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY, FOREIGN KEY(c) REFERENCES t2(b)) ENGINE = InnoDB; INSERT INTO t1 VALUES (1), (2), (5); INSERT INTO t2 VALUES (1); INSERT INTO t3 VALUES (1), (2); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) INSERT IGNORE INTO t3 VALUES (1), (2); Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE t3 SET c=2 where c=1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t3 SET c=2 where c=1; Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) DELETE FROM t1; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) DELETE IGNORE FROM t1; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) SELECT * FROM t1; a 1 UPDATE t2 SET b=b+5; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t2 SET b=b+5; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) SELECT * FROM t2; b 1 DROP TABLE t3,t2,t1; CREATE TABLE t1 (a int) ENGINE = InnoDB PARTITION BY HASH (a) PARTITIONS 2; INSERT INTO t1 VALUES (0), (1), (2), (3); CREATE VIEW v1 AS SELECT a FROM t1 PARTITION (p0); SELECT * FROM t1; a 0 2 1 3 SELECT * FROM v1; a 0 2 INSERT INTO v1 VALUES (10),(11); ERROR HY000: Found a row not matching the given partition set INSERT IGNORE INTO v1 VALUES (10),(11); Warnings: Warning 1748 Found a row not matching the given partition set UPDATE v1 SET a=11 WHERE a=2; ERROR HY000: Found a row not matching the given partition set UPDATE IGNORE v1 SET a=11 WHERE a=2; Warnings: Warning 1748 Found a row not matching the given partition set DROP VIEW v1; DROP TABLE t1; CREATE TABLE t1 (a int) ENGINE = InnoDB PARTITION BY LIST (a) (PARTITION x1 VALUES IN (2,5), PARTITION x2 VALUES IN (3)); INSERT INTO t1 VALUES (2), (3),(5); INSERT INTO t1 VALUES (2),(4); ERROR HY000: Table has no partition for value 4 INSERT IGNORE INTO t1 VALUES (2),(4); Warnings: Warning 1526 Table has no partition for value 4 UPDATE t1 SET a=4 WHERE a=5; ERROR HY000: Table has no partition for value 4 UPDATE IGNORE t1 SET a=4 WHERE a=5; Warnings: Warning 1526 Table has no partition for value 4 DROP TABLE t1; CREATE TABLE t11 (a INT NOT NULL, b INT, PRIMARY KEY (a)) ENGINE = InnoDB; CREATE TABLE t2 (a INT NOT NULL, b INT, PRIMARY KEY (a)) ENGINE = InnoDB; INSERT INTO t11 VALUES (0, 10),(1, 11),(2, 12); INSERT INTO t2 VALUES (1, 21),(2, 12),(3, 23); DELETE FROM t11 WHERE t11.b = (SELECT b FROM t2 WHERE t11.a < t2.a); ERROR 21000: Subquery returns more than 1 row DELETE IGNORE FROM t11 WHERE t11.b = (SELECT b FROM t2 WHERE t11.a < t2.a); Warnings: Warning 1242 Subquery returns more than 1 row Warning 1242 Subquery returns more than 1 row DROP TABLE t11, t2; CREATE TABLE t1 (a INT) ENGINE = InnoDB; CREATE VIEW v1 AS SELECT * FROM t1 WHERE a < 2 WITH CHECK OPTION; INSERT INTO v1 VALUES (1), (3); ERROR HY000: CHECK OPTION failed 'test.v1' INSERT IGNORE INTO v1 VALUES (1), (3); Warnings: Warning 1369 CHECK OPTION failed 'test.v1' UPDATE v1 SET a=5 WHERE a=1; ERROR HY000: CHECK OPTION failed 'test.v1' UPDATE IGNORE v1 SET a=5 WHERE a=1; Warnings: Warning 1369 CHECK OPTION failed 'test.v1' DROP VIEW v1; DROP TABLE t1; # # Part 3 : For the handler errors converted to warning # by IGNORE keyword. # # # Test For warning message for unique key constraint violation. # CREATE TABLE t1( a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2( a INT PRIMARY KEY) ENGINE = InnoDB; INSERT INTO t1 VALUES (1), (2), (3), (4); INSERT INTO t2 VALUES (2), (4); SELECT * INTO OUTFILE 'MYSQLTEST_VARDIR/tmp/wl6614.txt' FROM t1; SELECT LOAD_FILE('MYSQLTEST_VARDIR/tmp/wl6614.txt'); LOAD_FILE('MYSQLTEST_VARDIR/tmp/wl6614.txt') 1 2 3 4 LOAD DATA INFILE 'MYSQLTEST_VARDIR/tmp/wl6614.txt' INTO TABLE t2; ERROR 23000: Duplicate entry '2' for key 'PRIMARY' LOAD DATA INFILE 'MYSQLTEST_VARDIR/tmp/wl6614.txt' IGNORE INTO TABLE t2; Warnings: Warning 1062 Duplicate entry '2' for key 'PRIMARY' Warning 1062 Duplicate entry '4' for key 'PRIMARY' SELECT * FROM t2; a 1 2 3 4 DELETE FROM t2; INSERT INTO t2 VALUES (2),(4); LOAD DATA INFILE 'MYSQLTEST_VARDIR/tmp/wl6614.txt' IGNORE INTO TABLE t2; Warnings: Warning 1062 Duplicate entry '2' for key 'PRIMARY' Warning 1062 Duplicate entry '4' for key 'PRIMARY' SELECT * from t2; a 1 2 3 4 DROP TABLE t1,t2; # # Part 4 : For the error codes affected by STRICT Mode, # Using IGNORE + STRICT should give the behavior # Warning ---> Warning ( IGNORE+STRICT mode) # # #For Error Code : ER_NO_DEFAULT_FOR_FIELD # ER_NO_DEFAULT_FOR_VIEW_FIELD # DROP TABLE IF EXISTS t1; Warnings: Note 1051 Unknown table 'test.t1' CREATE TABLE t1 (col1 INT NOT NULL, col2 INT NOT NULL) ENGINE = InnoDB; CREATE VIEW v1 (vcol1) AS SELECT col1 FROM t1; INSERT INTO t1 (col1) VALUES(12); ERROR HY000: Field 'col2' doesn't have a default value INSERT IGNORE INTO t1 (col1) VALUES(12); Warnings: Warning 1364 Field 'col2' doesn't have a default value INSERT INTO v1 (vcol1) VALUES(12); ERROR HY000: Field of view 'test.v1' underlying table doesn't have a default value INSERT IGNORE INTO v1 (vcol1) VALUES(12); Warnings: Warning 1423 Field of view 'test.v1' underlying table doesn't have a default value DROP TABLE t1; DROP VIEW v1; # #For Error Code : ER_WARN_DATA_OUT_OF_RANGE # SET sql_mode=default; CREATE TABLE t1(a INT) ENGINE = InnoDB; INSERT INTO t1 VALUES(2147483648); ERROR 22003: Out of range value for column 'a' at row 1 INSERT IGNORE INTO t1 VALUES(2147483648); Warnings: Warning 1264 Out of range value for column 'a' at row 1 UPDATE IGNORE t1 SET a=2147483648 WHERE a=0; DROP TABLE t1; # #For Error Code : ER_TRUNCATED_WRONG_VALUE_FOR_FIELD # DROP TABLE IF EXISTS t1; Warnings: Note 1051 Unknown table 'test.t1' CREATE TABLE t1(a INT) ENGINE = InnoDB; INSERT INTO t1 values('a'); ERROR HY000: Incorrect integer value: 'a' for column 'a' at row 1 INSERT IGNORE INTO t1 values('a'); Warnings: Warning 1366 Incorrect integer value: 'a' for column 'a' at row 1 UPDATE IGNORE t1 SET a='a' WHERE a=0; Warnings: Warning 1366 Incorrect integer value: 'a' for column 'a' at row 1 DROP TABLE t1; # #For Error Code : ER_DATA_TOO_LONG # DROP TABLE IF EXISTS t3; Warnings: Note 1051 Unknown table 'test.t3' CREATE TABLE t3(c1 CHAR(10) NOT NULL) ENGINE = InnoDB; INSERT INTO t3 VALUES('a'); INSERT INTO t3 (c1) VALUES('12345678901.x'); ERROR 22001: Data too long for column 'c1' at row 1 INSERT IGNORE INTO t3 (c1) VALUES('12345678901.x'); Warnings: Warning 1265 Data truncated for column 'c1' at row 1 UPDATE IGNORE t3 SET c1='12345678901.x' WHERE c1='a'; Warnings: Warning 1265 Data truncated for column 'c1' at row 1 DROP TABLE t3; # #For Error Code : ER_WRONG_VALUE_FOR_TYPE # CREATE TABLE t1 (col1 DATETIME) ENGINE = InnoDB; INSERT INTO t1 VALUES('1000-01-01 00:00:00'); INSERT INTO t1 VALUES(STR_TO_DATE('32.10.2004 15.30','%D.%D.%Y %H.%I')); ERROR HY000: Incorrect datetime value: '32.10.2004 15.30' for function str_to_date INSERT IGNORE INTO t1 VALUES(STR_TO_DATE('32.10.2004 15.30','%D.%D.%Y %H.%I')); Warnings: Warning 1411 Incorrect datetime value: '32.10.2004 15.30' for function str_to_date Warning 1411 Incorrect datetime value: '32.10.2004 15.30' for function str_to_date UPDATE IGNORE t1 SET col1=STR_TO_DATE('32.10.2004 15.30','%D.%D.%Y %H.%I') WHERE col1='1000-01-01 00:00:00'; Warnings: Warning 1411 Incorrect datetime value: '32.10.2004 15.30' for function str_to_date Warning 1411 Incorrect datetime value: '32.10.2004 15.30' for function str_to_date DROP TABLE t1; # #For Error Code : ER_DATETIME_FUNCTION_OVERFLOW # CREATE TABLE t1 (d DATE) ENGINE = InnoDB; INSERT INTO t1 (d) SELECT DATE_SUB('2000-01-01', INTERVAL 2001 YEAR); ERROR 22008: Datetime function: datetime field overflow INSERT IGNORE INTO t1 (d) SELECT DATE_SUB('2000-01-01',INTERVAL 2001 YEAR); Warnings: Warning 1441 Datetime function: datetime field overflow DROP TABLE t1; # #For Error Code : ER_TRUNCATED_WRONG_VALUE # CREATE TABLE t1 (col1 CHAR(3), col2 INT) ENGINE = InnoDB; INSERT INTO t1 (col1) VALUES (CAST(1000 as CHAR(3))); ERROR 22007: Truncated incorrect CHAR(3) value: '1000' SELECT * FROM t1; col1 col2 INSERT IGNORE into t1 (col1) VALUES (CAST(1000 as CHAR(3))); Warnings: Warning 1292 Truncated incorrect CHAR(3) value: '1000' SELECT * FROM t1; col1 col2 100 NULL INSERT INTO t1 (col1) VALUES (CAST(1000 as CHAR(3))); ERROR 22007: Truncated incorrect CHAR(3) value: '1000' SELECT * FROM t1; col1 col2 100 NULL INSERT IGNORE into t1 (col1) VALUES (CAST(1000 as CHAR(3))); Warnings: Warning 1292 Truncated incorrect CHAR(3) value: '1000' SELECT * FROM t1; col1 col2 100 NULL 100 NULL DROP TABLE t1; # #For Error Code : ER_DIVISION_BY_ZERO #For Error Code : WARN_DATA_TRUNCATED # SET sql_mode='ERROR_FOR_DIVISION_BY_ZERO,STRICT_ALL_TABLES'; Warnings: Warning 3135 'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged with strict mode in a future release. Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. CREATE TABLE t1(a TINYINT); INSERT INTO t1 VALUES(2/0); ERROR 22012: Division by 0 INSERT IGNORE INTO t1 VALUES(2/0); Warnings: Warning 1365 Division by 0 SELECT * FROM t1; a NULL DELETE FROM t1; INSERT INTO t1 VALUES ('a59b'); ERROR HY000: Incorrect integer value: 'a59b' for column 'a' at row 1 INSERT IGNORE INTO t1 VALUES ('a59b'); Warnings: Warning 1366 Incorrect integer value: 'a59b' for column 'a' at row 1 INSERT INTO t1 VALUES ('1a'); ERROR 01000: Data truncated for column 'a' at row 1 INSERT IGNORE INTO t1 VALUES ('1a'); Warnings: Warning 1265 Data truncated for column 'a' at row 1 DROP TABLE t1; # #For Error Code : ER_WRONG_ARGUMENTS # CREATE TABLE t1(a INT) ENGINE = InnoDB; INSERT INTO t1(SELECT SLEEP(NULL)); ERROR HY000: Incorrect arguments to sleep. INSERT IGNORE into t1(SELECT SLEEP(NULL)); Warnings: Warning 1210 Incorrect arguments to sleep. SELECT * FROM t1; a 0 DROP TABLE t1; # #For Error Code : ER_WARN_NULL_TO_NOTNULL # CREATE TABLE t1(a INT, b INT NOT NULL, c INT NOT NULL, d INT NOT NULL) ENGINE = InnoDB; LOAD DATA INFILE '../../std_data/wl6030_2.dat' INTO TABLE t1 FIELDS TERMINATED BY ',' ENCLOSED BY '"'; ERROR 22004: Column set to default value; NULL supplied to NOT NULL column 'b' at row 3 SELECT * FROM t1; a b c d LOAD DATA INFILE '../../std_data/wl6030_2.dat' IGNORE INTO TABLE t1 FIELDS TERMINATED BY ',' ENCLOSED BY '"'; Warnings: Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'b' at row 3 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'c' at row 4 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'd' at row 5 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'b' at row 6 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'c' at row 6 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'd' at row 6 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'b' at row 7 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'c' at row 8 Warning 1263 Column set to default value; NULL supplied to NOT NULL column 'd' at row 9 SELECT * FROM t1; a b c d 11 12 13 14 NULL 22 23 24 31 0 33 34 41 42 0 44 51 52 53 0 NULL 0 0 0 NULL 0 73 74 NULL 82 0 84 NULL 92 93 0 DROP TABLE t1; SET sql_mode=@org_mode; Warnings: Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. # # Part 5 : Test cases for the non transactional (MyIsam) engine. # CREATE TABLE t1 (a int) ENGINE = MyISAM PARTITION BY HASH (a) PARTITIONS 2; Warnings: Warning 1287 The partition engine, used by table 'test.t1', is deprecated and will be removed in a future release. Please use native partitioning instead. INSERT INTO t1 VALUES (0), (1), (2), (3); Warnings: Warning 1287 The partition engine, used by table 'test.t1', is deprecated and will be removed in a future release. Please use native partitioning instead. CREATE VIEW v1 AS SELECT a FROM t1 PARTITION (p0); SHOW CREATE VIEW v1; View Create View character_set_client collation_connection v1 CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `v1` AS select `t1`.`a` AS `a` from `t1` PARTITION (`p0`) latin1 latin1_swedish_ci SELECT * FROM t1; a 0 2 1 3 SELECT * FROM v1; a 0 2 INSERT INTO v1 VALUES (10),(11); ERROR HY000: Found a row not matching the given partition set SELECT * from t1; a 0 2 10 1 3 INSERT IGNORE INTO v1 VALUES (10),(11); Warnings: Warning 1748 Found a row not matching the given partition set UPDATE IGNORE v1 SET a=11 WHERE a=2; Warnings: Warning 1748 Found a row not matching the given partition set SELECT * FROM v1; a 0 2 10 10 SELECT * from t1; a 0 2 10 10 1 3 DROP TABLE t1; DROP VIEW v1; CREATE TABLE t1 (a int) ENGINE = MyISAM PARTITION BY LIST (a) (PARTITION x1 VALUES IN (2,5), PARTITION x2 VALUES IN (3)); Warnings: Warning 1287 The partition engine, used by table 'test.t1', is deprecated and will be removed in a future release. Please use native partitioning instead. INSERT INTO t1 VALUES (2), (3),(5); Warnings: Warning 1287 The partition engine, used by table 'test.t1', is deprecated and will be removed in a future release. Please use native partitioning instead. INSERT INTO t1 VALUES (2),(4); ERROR HY000: Table has no partition for value 4 INSERT IGNORE INTO t1 VALUES (2),(4); Warnings: Warning 1526 Table has no partition for value 4 SELECT * FROM t1; a 2 5 2 2 3 UPDATE t1 SET a=a+1; ERROR HY000: Table has no partition for value 6 UPDATE IGNORE t1 SET a=a+1; Warnings: Warning 1526 Table has no partition for value 6 Warning 1526 Table has no partition for value 4 Warning 1526 Table has no partition for value 4 SELECT * FROM t1; a 5 3 3 3 3 DROP TABLE t1; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY, FOREIGN KEY(c) REFERENCES t2(b)) ENGINE = InnoDB; INSERT INTO t1 VALUES (1), (2), (5); INSERT INTO t2 VALUES (1); INSERT INTO t3 VALUES (1), (2); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) INSERT IGNORE INTO t3 VALUES (1), (2); Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE t3 SET c=2 where c=1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t3 SET c=2 where c=1; Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) DELETE FROM t1; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) DELETE IGNORE FROM t1; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) SELECT * FROM t1; a 1 UPDATE t2 SET b=b+5; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) UPDATE IGNORE t2 SET b=b+5; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) SELECT * FROM t2; b 1 DROP TABLE t3,t2,t1; CREATE TABLE t1 (a INT) ENGINE = MyISAM; INSERT INTO t1 VALUES (1),(NULL),(2); SET sql_mode = 'NO_ENGINE_SUBSTITUTION'; Warnings: Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. ALTER TABLE t1 CHANGE a a INT NOT NULL; Warnings: Warning 1265 Data truncated for column 'a' at row 2 SET sql_mode = default; SELECT * FROM t1; a 1 0 2 UPDATE IGNORE t1 SET a=NULL WHERE a=0; Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 1 0 2 DELETE FROM t1; INSERT INTO t1 VALUES (NULL); ERROR 23000: Column 'a' cannot be null INSERT IGNORE INTO t1 VALUES (NULL); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 INSERT IGNORE INTO t1 VALUES (NULL),(3); Warnings: Warning 1048 Column 'a' cannot be null SELECT * FROM t1; a 0 0 3 DROP TABLE t1; CREATE TABLE t1(a INT, b INT) ENGINE = MyISAM; CREATE TABLE t2(a INT, b INT NOT NULL) ENGINE = MyISAM; INSERT INTO t1 VALUES(1, NULL),(2,NULL); INSERT INTO t2 VALUES (1,3), (2,4); UPDATE IGNORE t1,t2 SET t2.b=NULL; Warnings: Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null UPDATE IGNORE t2,t1 SET t2.b=NULL; Warnings: Warning 1048 Column 'b' cannot be null Warning 1048 Column 'b' cannot be null DROP TABLE t1,t2; # # Part 6 : Miscellaneous Test cases # # This case checks that the number of warnings returned # after multiupdate is correct. CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT PRIMARY KEY, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY) ENGINE = InnoDB; INSERT INTO t1 VALUES (1); INSERT INTO t2 VALUES (1); INSERT INTO t3 VALUES (1); UPDATE IGNORE t1,t3 SET t1.a=5 where t1.a=t3.c; affected rows: 0 info: Rows matched: 1 Changed: 0 Warnings: 1 Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) UPDATE IGNORE t2,t3 SET t2.b=5 where t2.b=t3.c; affected rows: 0 info: Rows matched: 1 Changed: 0 Warnings: 1 Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) DROP TABLE t3,t2,t1; # Test cases to increase Code Coverage CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t2 (b INT PRIMARY KEY) ENGINE = InnoDB; CREATE TABLE t3 (c INT PRIMARY KEY, FOREIGN KEY(c) REFERENCES t2(b)) ENGINE = InnoDB; INSERT INTO t1 VALUES(1),(2); INSERT INTO t2 VALUES (3),(4); INSERT INTO t3 VALUES(3),(4); DELETE t1.*,t2.* FROM t1,t2; ERROR 23000: Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) DELETE IGNORE t1.*,t2.* FROM t1,t2; Warnings: Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) Warning 1451 Cannot delete or update a parent row: a foreign key constraint fails (`test`.`t3`, CONSTRAINT `t3_ibfk_1` FOREIGN KEY (`c`) REFERENCES `t2` (`b`)) SELECT * FROM t1; a SELECT * FROM t2; b 3 4 DROP TABLE t3,t2,t1; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=InnoDB; CREATE TABLE t2 (b INT PRIMARY KEY, FOREIGN KEY(b) REFERENCES t1(a)) ENGINE=InnoDB; INSERT INTO t1 VALUES(1); INSERT INTO t2 VALUES(2) ON DUPLICATE KEY UPDATE b=b-1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) INSERT IGNORE INTO t2 VALUES(2) ON DUPLICATE KEY UPDATE b=b-1; Warnings: Warning 1452 Cannot add or update a child row: a foreign key constraint fails (`test`.`t2`, CONSTRAINT `t2_ibfk_1` FOREIGN KEY (`b`) REFERENCES `t1` (`a`)) DROP table t2,t1; # # Bug#14786621 ASSERTION FAILED: THD->IS_ERROR() || KILL: # FILESORT + DISCARDED TABLESPACE # CREATE TABLE t(a int) engine=innodb; ALTER TABLE t DISCARD TABLESPACE; DELETE IGNORE FROM t ; ERROR HY000: Tablespace has been discarded for table 't' DELETE IGNORE FROM t ORDER BY 0 + 1 ; ERROR HY000: Tablespace has been discarded for table 't' DROP TABLE t; # # BUG#18526888 - STRICT MODE DOES NOT APPLY TO MULTI DELETE STATEMENT # CREATE TABLE t1(a INT); INSERT INTO t1 VALUES(5); CREATE TABLE t2(b int); INSERT INTO t2 VALUES(7); # # STRICT MODE and IGNORE test case for DELETE # DELETE FROM t1 where a <=> ln(0); ERROR 2201E: Invalid argument for logarithm DELETE IGNORE FROM t1 where a <=> ln(0); Warnings: Warning 3020 Invalid argument for logarithm SHOW WARNINGS; Level Code Message Warning 3020 Invalid argument for logarithm # # STRICT MODE and IGNORE test case for MULTI DELETE # An error ER_INVALID_ARGUMENT_FOR_LOGARITHM is expected here. # DELETE t1, t2 FROM t1 INNER JOIN t2 WHERE t1.a <=> ln(0) AND t2.b <=> ln(0); ERROR 2201E: Invalid argument for logarithm # Warnings are expected here and works fine. DELETE IGNORE t1, t2 FROM t1 INNER JOIN t2 WHERE t1.a <=> ln(0) AND t2.b <=> ln(0); Warnings: Warning 3020 Invalid argument for logarithm SHOW WARNINGS; Level Code Message Warning 3020 Invalid argument for logarithm # Clean-up DROP TABLE t1,t2; # Restore the orginal sql_mode SET sql_mode= @org_mode; # # BUG 18662121 - ASSERT IN PROTOCOL::END_STATEMENT() IN LOAD DATA STATEMENT # SET sql_mode='STRICT_TRANS_TABLES'; Warnings: Warning 3135 'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged with strict mode in a future release. Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. CREATE TABLE t2 (a int default 0, b int primary key) engine=innodb; INSERT INTO t2 VALUES (0, 17); LOAD DATA INFILE '../../std_data/rpl_loaddata.dat' INTO TABLE t2 (a, @b) SET b= @b + 2; ERROR 23000: Duplicate entry '17' for key 'PRIMARY' DROP TABLE t2; SET sql_mode= @org_mode; Warnings: Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. # # BUG#18662043 - ASSERT IN MY_OK() IN SQL_CMD_SIGNAL::EXECUTE # SET sql_mode='STRICT_TRANS_TABLES'; Warnings: Warning 3135 'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged with strict mode in a future release. Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. CREATE PROCEDURE p1() BEGIN # warning DECLARE too_few_records CONDITION FOR SQLSTATE '01000'; SIGNAL too_few_records SET MYSQL_ERRNO = 1261; END | # This statement should pass with the fix. CALL p1(); Warnings: Warning 1261 Unhandled user-defined warning condition # Clean-up DROP PROCEDURE p1; # Restore the orginal sql_mode SET sql_mode= @org_mode; Warnings: Warning 3090 Changing sql mode 'NO_AUTO_CREATE_USER' is deprecated. It will be removed in a future release. # # Bug #19873291 : MYSQL_EXECUTE_COMMAND(THD*): ASSERTION # `THD->IS_ERROR() || THD->KILLED' FAILED # CREATE TABLE t1(a INT); SET @org_safe_updates= @@sql_safe_updates; SET SESSION sql_safe_updates=ON; DELETE IGNORE FROM t1 WHERE a=1; ERROR HY000: You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column. DROP TABLE t1; SET sql_safe_updates= @org_safe_updates;