config root man

Current Path : /usr/opt/mysql57/mysql-test/t/

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
Upload File :
Current File : //usr/opt/mysql57/mysql-test/t/ignore_strict.test

#        This test file contains test cases divided in 6 different parts.
#        Part 1 : Statments WITH IGNORE (Error to Warning )
#        Part 2 : Statements WITH IGNORE in STRICT Mode ( Error to Warning )
#
#        Part 3:  This contains all the missing test cases for the handler errors
#                 converted to warning message by the IGNORE keyword.
#
#
#        Part 4 : Error Codes affected by STRICT mode
#                 Default behavior is Warning.
#                 In STRICT mode : Error
#                 WITH IGNORE in STRICT Mode: Warning
#                 Using IGNORE + STRICT mode keeps the default bevavior.
#
#        Part 5 : Test cases for the non transactional (MyIsam) engine.
#
#        Part 6 : Miscellaneous/ Other Test cases
#



--echo
--echo #
--echo # Part 1 : Statements with IGNORE to convert Errors to Warnings.
--echo #
--echo

#Store the original SQL_Mode in org_mode variable.
SET @org_mode=@@sql_mode;

--echo #
--echo #For Error Code : ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
--echo #

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;
SELECT * FROM v1;
--error ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
INSERT INTO v1 VALUES (10),(11);
INSERT IGNORE INTO v1 VALUES (10),(11);
UPDATE IGNORE v1 SET a=11 WHERE a=2;
SELECT * FROM v1;
SELECT * from t1;
DROP TABLE t1;
DROP VIEW v1;

--echo #
--echo #For Error Code : ER_NO_PARTITION_FOR_GIVEN_VALUE
--echo #                 ER_NO_PARTITION_FOR_GIVEN_VALUE_SILENT
--echo #
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);
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
INSERT INTO t1 VALUES (2),(4);
INSERT IGNORE INTO t1 VALUES (2),(4);
SELECT * FROM t1;
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
UPDATE t1 SET a=a+1;
UPDATE IGNORE t1 SET a=a+1;
SELECT * FROM t1;
DROP TABLE t1;

#ER_ROW_IS_REFERENCED_2
#ER_NO_REFERENCED_ROW_2
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);
--error ER_NO_REFERENCED_ROW_2
INSERT INTO t3 VALUES (1), (2);
INSERT IGNORE INTO t3 VALUES (1), (2);
--error ER_NO_REFERENCED_ROW_2
UPDATE t3 SET c=2 where c=1;
UPDATE IGNORE t3 SET c=2 where c=1;

--error ER_ROW_IS_REFERENCED_2
DELETE FROM t1;
DELETE IGNORE FROM t1;
SELECT * FROM t1;
--error ER_ROW_IS_REFERENCED_2
UPDATE t2 SET b=b+5;
UPDATE IGNORE t2 SET b=b+5;
SELECT * FROM t2;

DROP TABLE t3,t2,t1;

#ER_BAD_NULL_ERROR
CREATE TABLE t1 (a INT) ENGINE = InnoDB;
INSERT INTO t1 VALUES (1),(NULL),(2);
SET sql_mode = 'NO_ENGINE_SUBSTITUTION';
ALTER TABLE t1 CHANGE a a INT NOT NULL;
SET sql_mode = default;
SELECT * FROM t1;
UPDATE IGNORE t1 SET a=NULL WHERE a=0;
SELECT * FROM t1;
DELETE FROM t1;
--error ER_BAD_NULL_ERROR
INSERT INTO t1 VALUES (NULL);
INSERT IGNORE INTO t1 VALUES (NULL);
SELECT * FROM t1;
INSERT IGNORE INTO t1 VALUES (NULL),(3);
SELECT * FROM t1;
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;
DROP TABLE t1,t2;

--echo #
--echo # IGNORE keyword in the statement should not affect the errors in the
--echo # trigger execution if trigger statement does not have IGNORE keyword.
--echo # and vice versa.
--echo #

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);
DELIMITER |;
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|
DELIMITER ;|
--error ER_DUP_ENTRY
INSERT IGNORE INTO t1 VALUES(3);
SELECT * FROM t1;
--error ER_DUP_ENTRY
UPDATE IGNORE t1 SET a=3 WHERE a=2;
SELECT * FROM t1;

DROP TRIGGER post_insert_t1;
DROP TRIGGER post_update_t1;

DELIMITER |;
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|
DELIMITER ;|
--error ER_DUP_ENTRY
INSERT INTO t1 VALUES(2);
SELECT * FROM t3;
INSERT IGNORE INTO t1 VALUES(2),(3);
SELECT * FROM t1;
SELECT * FROM t3;
UPDATE IGNORE t1 SET a=3 WHERE a=2;

DROP TRIGGER post_insert_t1;
DROP TRIGGER post_update_t1;

DROP TABLE t2,t1,t3;

--echo
--echo #
--echo # Part 2 : Statements with IGNORE + STRICT
--echo #          These statements gives error by default
--echo #           without IGNORE and STRICT mode.
--echo #
--echo

SET sql_mode=default;
#ER_BAD_NULL_ERROR
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;
--error ER_BAD_NULL_ERROR
INSERT INTO t1 VALUES (NULL);
INSERT IGNORE INTO t1 VALUES(NULL);
SELECT * FROM t1;
--error ER_BAD_NULL_ERROR
INSERT INTO t1 VALUES (NULL),(3);
INSERT IGNORE INTO t1 VALUES (NULL),(1);
SELECT * FROM t1;
--error ER_BAD_NULL_ERROR
UPDATE t1 SET a=NULL WHERE a=0;
UPDATE IGNORE t1 SET a=NULL WHERE a=0;
SELECT * FROM t1;
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);
--error ER_BAD_NULL_ERROR
UPDATE t1,t2 SET t2.b=NULL;
UPDATE IGNORE t1,t2 SET t2.b=NULL;
DROP TABLE t1, t2;
#ER_ROW_IS_REFERENCED_2
#ER_NO_REFERENCED_ROW_2
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);
--error ER_NO_REFERENCED_ROW_2
INSERT INTO t3 VALUES (1), (2);
INSERT IGNORE INTO t3 VALUES (1), (2);
--error ER_NO_REFERENCED_ROW_2
UPDATE t3 SET c=2 where c=1;
UPDATE IGNORE t3 SET c=2 where c=1;

--error ER_ROW_IS_REFERENCED_2
DELETE FROM t1;
DELETE IGNORE FROM t1;
SELECT * FROM t1;
--error ER_ROW_IS_REFERENCED_2
UPDATE t2 SET b=b+5;
UPDATE IGNORE t2 SET b=b+5;
SELECT * FROM t2;

DROP TABLE t3,t2,t1;

#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;
SELECT * FROM v1;
--error ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
INSERT INTO v1 VALUES (10),(11);
INSERT IGNORE INTO v1 VALUES (10),(11);
--error ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
UPDATE v1 SET a=11 WHERE a=2;
UPDATE IGNORE v1 SET a=11 WHERE a=2;
DROP VIEW v1;
DROP TABLE t1;

#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);
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
INSERT INTO t1 VALUES (2),(4);
INSERT IGNORE INTO t1 VALUES (2),(4);
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
UPDATE t1 SET a=4 WHERE a=5;
UPDATE IGNORE t1 SET a=4 WHERE a=5;
DROP TABLE t1;

#ER_SUBQUERY_NO_1_ROW
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);
--error ER_SUBQUERY_NO_1_ROW
DELETE FROM t11 WHERE t11.b = (SELECT b FROM t2 WHERE t11.a < t2.a);
DELETE IGNORE FROM t11 WHERE t11.b = (SELECT b FROM t2 WHERE t11.a < t2.a);
DROP TABLE t11, t2;

#ER_VIEW_CHECK_FAILED
CREATE TABLE t1 (a INT) ENGINE = InnoDB;
CREATE VIEW v1 AS SELECT * FROM t1 WHERE a < 2 WITH CHECK OPTION;
--error ER_VIEW_CHECK_FAILED
INSERT INTO v1 VALUES (1), (3);
INSERT IGNORE INTO v1 VALUES (1), (3);
--error ER_VIEW_CHECK_FAILED
UPDATE v1 SET a=5 WHERE a=1;
UPDATE IGNORE v1 SET a=5 WHERE a=1;
DROP VIEW v1;
DROP TABLE t1;


--echo
--echo #
--echo # Part 3 : For the handler errors converted to warning
--echo #             by IGNORE keyword.
--echo #
--echo

--echo #
--echo # Test For warning message for unique key constraint violation.
--echo #

# Part 2 covers most of the test case for this section.

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);
--let $fields=*
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
--eval SELECT $fields INTO OUTFILE '$MYSQLTEST_VARDIR/tmp/wl6614.txt' FROM t1
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
--eval SELECT LOAD_FILE('$MYSQLTEST_VARDIR/tmp/wl6614.txt')
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
--error ER_DUP_ENTRY
--eval LOAD DATA INFILE '$MYSQLTEST_VARDIR/tmp/wl6614.txt' INTO TABLE t2
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
--eval LOAD DATA INFILE '$MYSQLTEST_VARDIR/tmp/wl6614.txt' IGNORE INTO TABLE t2
--eval SELECT $fields FROM t2
DELETE FROM t2;
INSERT INTO t2 VALUES (2),(4);
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
--eval LOAD DATA INFILE '$MYSQLTEST_VARDIR/tmp/wl6614.txt' IGNORE INTO TABLE t2
SELECT * from t2;
--remove_file $MYSQLTEST_VARDIR/tmp/wl6614.txt
DROP TABLE t1,t2;

--echo
--echo #
--echo # Part 4 : For the error codes affected by STRICT Mode,
--echo #          Using IGNORE + STRICT should give the behavior
--echo #          Warning --->  Warning ( IGNORE+STRICT mode)
--echo #
--echo
--echo #
--echo #For Error Code : ER_NO_DEFAULT_FOR_FIELD
--echo #                 ER_NO_DEFAULT_FOR_VIEW_FIELD
--echo #
DROP TABLE IF EXISTS t1;
CREATE TABLE t1 (col1 INT NOT NULL, col2 INT NOT NULL) ENGINE = InnoDB;
CREATE VIEW v1 (vcol1) AS SELECT col1 FROM t1;
--error ER_NO_DEFAULT_FOR_FIELD
INSERT INTO t1 (col1) VALUES(12);
INSERT IGNORE INTO t1 (col1) VALUES(12);
--error ER_NO_DEFAULT_FOR_VIEW_FIELD
INSERT INTO v1 (vcol1) VALUES(12);
INSERT IGNORE INTO v1 (vcol1) VALUES(12);
DROP TABLE t1;
DROP VIEW v1;

--echo #
--echo #For Error Code : ER_WARN_DATA_OUT_OF_RANGE
--echo #
SET sql_mode=default;
CREATE TABLE t1(a INT) ENGINE = InnoDB;
--error ER_WARN_DATA_OUT_OF_RANGE
INSERT INTO t1 VALUES(2147483648);
INSERT IGNORE INTO t1 VALUES(2147483648);
UPDATE IGNORE t1 SET a=2147483648 WHERE a=0;
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
--echo #
DROP TABLE IF EXISTS t1;
CREATE TABLE t1(a INT) ENGINE = InnoDB;
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
INSERT INTO t1 values('a');
INSERT IGNORE INTO t1 values('a');
UPDATE IGNORE t1 SET a='a' WHERE a=0;
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_DATA_TOO_LONG
--echo #
DROP TABLE IF EXISTS t3;
CREATE TABLE t3(c1 CHAR(10) NOT NULL) ENGINE = InnoDB;
INSERT INTO t3 VALUES('a');
--error ER_DATA_TOO_LONG
INSERT INTO t3 (c1) VALUES('12345678901.x');
INSERT IGNORE INTO t3 (c1) VALUES('12345678901.x');
UPDATE IGNORE t3 SET c1='12345678901.x' WHERE c1='a';
DROP TABLE t3;

--echo #
--echo #For Error Code : ER_WRONG_VALUE_FOR_TYPE
--echo #
CREATE TABLE t1 (col1 DATETIME) ENGINE = InnoDB;
INSERT INTO t1 VALUES('1000-01-01 00:00:00');
--error ER_WRONG_VALUE_FOR_TYPE
INSERT INTO t1 VALUES(STR_TO_DATE('32.10.2004 15.30','%D.%D.%Y %H.%I'));
INSERT IGNORE INTO t1 VALUES(STR_TO_DATE('32.10.2004 15.30','%D.%D.%Y %H.%I'));
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';
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_DATETIME_FUNCTION_OVERFLOW
--echo #
CREATE TABLE t1 (d DATE) ENGINE = InnoDB;
--error ER_DATETIME_FUNCTION_OVERFLOW
INSERT INTO t1 (d) SELECT DATE_SUB('2000-01-01', INTERVAL 2001 YEAR);
INSERT IGNORE INTO t1 (d) SELECT DATE_SUB('2000-01-01',INTERVAL 2001 YEAR);
DROP TABLE t1;


--echo #
--echo #For Error Code : ER_TRUNCATED_WRONG_VALUE
--echo #

CREATE TABLE t1 (col1 CHAR(3), col2 INT) ENGINE = InnoDB;
--error ER_TRUNCATED_WRONG_VALUE
INSERT INTO t1 (col1) VALUES (CAST(1000 as CHAR(3)));
SELECT * FROM t1;
INSERT IGNORE into t1 (col1) VALUES (CAST(1000 as CHAR(3)));
SELECT * FROM t1;
--error ER_TRUNCATED_WRONG_VALUE
INSERT INTO t1 (col1) VALUES (CAST(1000 as CHAR(3)));
SELECT * FROM t1;
INSERT IGNORE into t1 (col1) VALUES (CAST(1000 as CHAR(3)));
SELECT * FROM t1;
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_DIVISION_BY_ZERO
--echo #For Error Code : WARN_DATA_TRUNCATED
--echo #

SET sql_mode='ERROR_FOR_DIVISION_BY_ZERO,STRICT_ALL_TABLES';
CREATE TABLE t1(a TINYINT);
--error ER_DIVISION_BY_ZERO
INSERT INTO t1 VALUES(2/0);
INSERT IGNORE INTO t1 VALUES(2/0);
SELECT * FROM t1;
DELETE FROM t1;
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
INSERT INTO t1 VALUES ('a59b');
INSERT IGNORE INTO t1 VALUES ('a59b');
--error 1265
INSERT INTO t1 VALUES ('1a');
INSERT IGNORE INTO t1 VALUES ('1a');
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_WRONG_ARGUMENTS
--echo #

CREATE TABLE t1(a INT) ENGINE = InnoDB;
--error ER_WRONG_ARGUMENTS
INSERT INTO t1(SELECT SLEEP(NULL));
INSERT IGNORE into t1(SELECT SLEEP(NULL));
SELECT * FROM t1;
DROP TABLE t1;

--echo #
--echo #For Error Code : ER_WARN_NULL_TO_NOTNULL
--echo #

CREATE TABLE t1(a INT, b INT NOT NULL, c INT NOT NULL, d INT NOT NULL) ENGINE = InnoDB;
--error ER_WARN_NULL_TO_NOTNULL
LOAD DATA INFILE '../../std_data/wl6030_2.dat' INTO TABLE t1 FIELDS TERMINATED BY ',' ENCLOSED BY '"';
SELECT * FROM t1;
LOAD DATA INFILE '../../std_data/wl6030_2.dat' IGNORE INTO TABLE t1 FIELDS TERMINATED BY ',' ENCLOSED BY '"';
SELECT * FROM t1;
DROP TABLE t1;


#Restore the Orignal SQL_Mode
SET sql_mode=@org_mode;

--echo
--echo #
--echo # Part 5 : Test cases for the non transactional (MyIsam) engine.
--echo #

#For Error Code : ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
CREATE TABLE t1 (a int) ENGINE = MyISAM PARTITION BY HASH (a) PARTITIONS 2;
INSERT INTO t1 VALUES (0), (1), (2), (3);
CREATE VIEW v1 AS SELECT a FROM t1 PARTITION (p0);
SHOW CREATE VIEW v1;
SELECT * FROM t1;
SELECT * FROM v1;
--error ER_ROW_DOES_NOT_MATCH_GIVEN_PARTITION_SET
INSERT INTO v1 VALUES (10),(11);
SELECT * from t1;
INSERT IGNORE INTO v1 VALUES (10),(11);
UPDATE IGNORE v1 SET a=11 WHERE a=2;
SELECT * FROM v1;
SELECT * from t1;
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 = MyISAM PARTITION BY LIST (a)
(PARTITION x1 VALUES IN (2,5), PARTITION x2 VALUES IN (3));
INSERT INTO t1 VALUES (2), (3),(5);
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
INSERT INTO t1 VALUES (2),(4);
INSERT IGNORE INTO t1 VALUES (2),(4);
SELECT * FROM t1;
--error ER_NO_PARTITION_FOR_GIVEN_VALUE
UPDATE t1 SET a=a+1;
UPDATE IGNORE t1 SET a=a+1;
SELECT * FROM t1;
DROP TABLE t1;

#ER_DUP_ENTRY
#ER_NO_REFERENCED_ROW_2
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);
--error ER_NO_REFERENCED_ROW_2
INSERT INTO t3 VALUES (1), (2);
INSERT IGNORE INTO t3 VALUES (1), (2);
--error ER_NO_REFERENCED_ROW_2
UPDATE t3 SET c=2 where c=1;
UPDATE IGNORE t3 SET c=2 where c=1;

--error ER_ROW_IS_REFERENCED_2
DELETE FROM t1;
DELETE IGNORE FROM t1;
SELECT * FROM t1;
--error ER_ROW_IS_REFERENCED_2
UPDATE t2 SET b=b+5;
UPDATE IGNORE t2 SET b=b+5;
SELECT * FROM t2;

DROP TABLE t3,t2,t1;

#ER_BAD_NULL_ERROR
CREATE TABLE t1 (a INT) ENGINE = MyISAM;
INSERT INTO t1 VALUES (1),(NULL),(2);
SET sql_mode = 'NO_ENGINE_SUBSTITUTION';
ALTER TABLE t1 CHANGE a a INT NOT NULL;
SET sql_mode = default;
SELECT * FROM t1;
UPDATE IGNORE t1 SET a=NULL WHERE a=0;
SELECT * FROM t1;
DELETE FROM t1;
--error ER_BAD_NULL_ERROR
INSERT INTO t1 VALUES (NULL);
INSERT IGNORE INTO t1 VALUES (NULL);
SELECT * FROM t1;
INSERT IGNORE INTO t1 VALUES (NULL),(3);
SELECT * FROM t1;
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;
UPDATE IGNORE t2,t1 SET t2.b=NULL;
DROP TABLE t1,t2;

--echo
--echo #
--echo # Part 6 : Miscellaneous Test cases
--echo #
--echo

--echo # This case checks that the number of warnings returned
--echo # 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);
--enable_info
UPDATE IGNORE t1,t3 SET t1.a=5 where t1.a=t3.c;
UPDATE IGNORE t2,t3 SET t2.b=5 where t2.b=t3.c;
--disable_info
DROP TABLE t3,t2,t1;

--echo # 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);
--error ER_ROW_IS_REFERENCED_2
DELETE t1.*,t2.* FROM t1,t2;
DELETE IGNORE t1.*,t2.* FROM t1,t2;
SELECT * FROM t1;
SELECT * FROM t2;
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);
--error ER_NO_REFERENCED_ROW_2
INSERT INTO t2 VALUES(2) ON DUPLICATE KEY UPDATE b=b-1;
INSERT IGNORE INTO t2 VALUES(2) ON DUPLICATE KEY UPDATE b=b-1;
DROP table t2,t1;

--echo #
--echo # Bug#14786621 ASSERTION FAILED: THD->IS_ERROR() || KILL:
--echo #              FILESORT + DISCARDED TABLESPACE
--echo #
CREATE TABLE t(a int) engine=innodb;
ALTER TABLE t DISCARD TABLESPACE;

--error ER_TABLESPACE_DISCARDED
DELETE IGNORE FROM t ;
--error ER_TABLESPACE_DISCARDED
DELETE IGNORE FROM t ORDER BY 0 + 1 ;

DROP TABLE t;

--echo #
--echo # BUG#18526888 - STRICT MODE DOES NOT APPLY TO MULTI DELETE STATEMENT
--echo #
CREATE TABLE t1(a INT);
INSERT INTO t1 VALUES(5);
CREATE TABLE t2(b int);
INSERT INTO t2 VALUES(7);

--echo #
--echo # STRICT MODE and IGNORE test case for DELETE
--echo #
--error ER_INVALID_ARGUMENT_FOR_LOGARITHM
DELETE FROM t1 where a <=> ln(0);
DELETE IGNORE FROM t1 where a <=> ln(0);
SHOW WARNINGS;

--echo #
--echo # STRICT MODE and IGNORE test case for MULTI DELETE
--echo # An error ER_INVALID_ARGUMENT_FOR_LOGARITHM is expected here.
--echo #
--error ER_INVALID_ARGUMENT_FOR_LOGARITHM
DELETE t1, t2 FROM t1 INNER JOIN t2 WHERE t1.a <=> ln(0) AND t2.b <=> ln(0);
--echo # 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);
SHOW WARNINGS;

--echo # Clean-up
DROP TABLE t1,t2;
--echo # Restore the orginal sql_mode
SET sql_mode= @org_mode;

--echo #
--echo # BUG 18662121 - ASSERT IN PROTOCOL::END_STATEMENT() IN LOAD DATA STATEMENT
--echo #
SET sql_mode='STRICT_TRANS_TABLES';

CREATE TABLE t2 (a int default 0, b int primary key) engine=innodb;
INSERT INTO t2 VALUES (0, 17);

# This statement should not assert with the fix.
--error ER_DUP_ENTRY
LOAD DATA INFILE '../../std_data/rpl_loaddata.dat' INTO TABLE t2 (a, @b) SET b= @b + 2;

#Clean-up
DROP TABLE t2;
# Restore the orginal sql_mode
SET sql_mode= @org_mode;

--echo #
--echo # BUG#18662043 - ASSERT IN MY_OK() IN SQL_CMD_SIGNAL::EXECUTE
--echo #
SET sql_mode='STRICT_TRANS_TABLES';

DELIMITER |;

CREATE PROCEDURE p1()
BEGIN
  # warning
  DECLARE too_few_records CONDITION FOR SQLSTATE '01000';
  SIGNAL too_few_records SET MYSQL_ERRNO = 1261;
END |

DELIMITER ;|

--echo # This statement should pass with the fix.
CALL p1();

--echo # Clean-up
DROP PROCEDURE p1;
--echo # Restore the orginal sql_mode
SET sql_mode= @org_mode;

--echo #
--echo # Bug #19873291 : MYSQL_EXECUTE_COMMAND(THD*): ASSERTION
--echo #                 `THD->IS_ERROR() || THD->KILLED' FAILED
--echo #
CREATE TABLE t1(a INT);
SET @org_safe_updates= @@sql_safe_updates;
SET SESSION sql_safe_updates=ON;
#This statement used to trigger an assert in DEBUG build before WL#6614
--error ER_UPDATE_WITHOUT_KEY_IN_SAFE_MODE
DELETE IGNORE FROM t1 WHERE a=1;
DROP TABLE t1;
SET sql_safe_updates= @org_safe_updates;

Man Man