drop table if exists t1,t2,v1,v2; drop view if exists t1,t2,v1,v2; CREATE TABLE `t1` ( a int not null auto_increment, `pseudo` varchar(35) character set latin2 NOT NULL default '', `email` varchar(60) character set latin2 NOT NULL default '', PRIMARY KEY (a), UNIQUE KEY `email` USING BTREE (`email`) ) ENGINE=HEAP CHARSET=latin1 ROW_FORMAT DYNAMIC; set @@sql_mode=""; show variables like 'sql_mode'; Variable_name Value sql_mode show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` int(11) NOT NULL AUTO_INCREMENT, `pseudo` varchar(35) CHARACTER SET latin2 NOT NULL DEFAULT '', `email` varchar(60) CHARACTER SET latin2 NOT NULL DEFAULT '', PRIMARY KEY (`a`), UNIQUE KEY `email` (`email`) USING BTREE ) ENGINE=MEMORY DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC set @@sql_mode="ansi_quotes"; show variables like 'sql_mode'; Variable_name Value sql_mode ANSI_QUOTES show create table t1; Table Create Table t1 CREATE TABLE "t1" ( "a" int(11) NOT NULL AUTO_INCREMENT, "pseudo" varchar(35) CHARACTER SET latin2 NOT NULL DEFAULT '', "email" varchar(60) CHARACTER SET latin2 NOT NULL DEFAULT '', PRIMARY KEY ("a"), UNIQUE KEY "email" ("email") USING BTREE ) ENGINE=MEMORY DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC set @@sql_mode="no_table_options"; show variables like 'sql_mode'; Variable_name Value sql_mode NO_TABLE_OPTIONS show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` int(11) NOT NULL AUTO_INCREMENT, `pseudo` varchar(35) CHARACTER SET latin2 NOT NULL DEFAULT '', `email` varchar(60) CHARACTER SET latin2 NOT NULL DEFAULT '', PRIMARY KEY (`a`), UNIQUE KEY `email` (`email`) USING BTREE ) set @@sql_mode="no_key_options"; show variables like 'sql_mode'; Variable_name Value sql_mode NO_KEY_OPTIONS show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` int(11) NOT NULL AUTO_INCREMENT, `pseudo` varchar(35) CHARACTER SET latin2 NOT NULL DEFAULT '', `email` varchar(60) CHARACTER SET latin2 NOT NULL DEFAULT '', PRIMARY KEY (`a`), UNIQUE KEY `email` (`email`) ) ENGINE=MEMORY DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC set @@sql_mode="no_field_options,mysql323,mysql40"; show variables like 'sql_mode'; Variable_name Value sql_mode NO_FIELD_OPTIONS,MYSQL323,MYSQL40,HIGH_NOT_PRECEDENCE show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` int(11) NOT NULL, `pseudo` varchar(35) NOT NULL DEFAULT '', `email` varchar(60) NOT NULL DEFAULT '', PRIMARY KEY (`a`), UNIQUE KEY `email` (`email`) ) TYPE=MEMORY ROW_FORMAT=DYNAMIC set sql_mode="postgresql,oracle,mssql,db2,maxdb"; select @@sql_mode; @@sql_mode PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,POSTGRESQL,ORACLE,MSSQL,DB2,MAXDB,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS,NO_AUTO_CREATE_USER,SIMULTANEOUS_ASSIGNMENT show create table t1; Table Create Table t1 CREATE TABLE "t1" ( "a" int(11) NOT NULL, "pseudo" varchar(35) CHARACTER SET latin2 NOT NULL DEFAULT '', "email" varchar(60) CHARACTER SET latin2 NOT NULL DEFAULT '', PRIMARY KEY ("a"), UNIQUE KEY "email" ("email") ) drop table t1; CREATE TABLE t1 ( a char(10), b char(10) collate latin1_bin, c binary(10) ) character set latin1; set @@sql_mode=""; show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` char(10) DEFAULT NULL, `b` char(10) CHARACTER SET latin1 COLLATE latin1_bin DEFAULT NULL, `c` binary(10) DEFAULT NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 set @@sql_mode="mysql323"; show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` char(10) DEFAULT NULL, `b` char(10) binary DEFAULT NULL, `c` binary(10) DEFAULT NULL ) TYPE=MyISAM set @@sql_mode="mysql40"; show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `a` char(10) DEFAULT NULL, `b` char(10) binary DEFAULT NULL, `c` binary(10) DEFAULT NULL ) TYPE=MyISAM drop table t1; set session sql_mode = ''; create table t1 ( min_num dec(6,6) default .000001); show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `min_num` decimal(6,6) DEFAULT 0.000001 ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1 ; set session sql_mode = 'IGNORE_SPACE'; create table t1 ( min_num dec(6,6) default 0.000001); show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `min_num` decimal(6,6) DEFAULT 0.000001 ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1 ; create table t1 ( min_num dec(6,6) default .000001); show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `min_num` decimal(6,6) DEFAULT 0.000001 ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1 ; set @@SQL_MODE=NULL; ERROR 42000: Variable 'sql_mode' can't be set to the value of 'NULL' set session sql_mode=ansi; create table t1 (f1 integer auto_increment primary key, f2 timestamp not null default current_timestamp on update current_timestamp); show create table t1; Table Create Table t1 CREATE TABLE "t1" ( "f1" int(11) NOT NULL AUTO_INCREMENT, "f2" timestamp NOT NULL DEFAULT current_timestamp() ON UPDATE current_timestamp(), PRIMARY KEY ("f1") ) set session sql_mode=no_field_options; show create table t1; Table Create Table t1 CREATE TABLE `t1` ( `f1` int(11) NOT NULL, `f2` timestamp NOT NULL DEFAULT current_timestamp(), PRIMARY KEY (`f1`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1; SET @OLD_SQL_MODE=@@SQL_MODE, @@SQL_MODE=''; show local variables like 'SQL_MODE'; Variable_name Value sql_mode CREATE TABLE t1 (p int not null auto_increment, a varchar(20), primary key(p)); INSERT t1 (a) VALUES ('\\'), ('\n'), ('\b'), ('\r'), ('\t'), ('\x'), ('\a'), ('\aa'), ('\\a'), ('\\aa'), ('_'), ('\_'), ('\\_'), ('\\\_'), ('\\\\_'), ('%'), ('\%'), ('\\%'), ('\\\%'), ('\\\\%') ; SELECT p, hex(a) FROM t1; p hex(a) 1 5C 2 0A 3 08 4 0D 5 09 6 78 7 61 8 6161 9 5C61 10 5C6161 11 5F 12 5C5F 13 5C5F 14 5C5C5F 15 5C5C5F 16 25 17 5C25 18 5C25 19 5C5C25 20 5C5C25 delete from t1 where a in ('\n','\r','\t', '\b'); select masks.p, masks.a as mask, examples.a as example from t1 as masks left join t1 as examples on examples.a LIKE masks.a order by masks.p, example; p mask example 1 \ \ 6 x x 7 a a 8 aa aa 9 \a a 10 \aa aa 11 _ % 11 _ a 11 _ x 11 _ \ 11 _ _ 12 \_ _ 13 \_ _ 14 \\_ \% 14 \\_ \% 14 \\_ \a 14 \\_ \_ 14 \\_ \_ 15 \\_ \% 15 \\_ \% 15 \\_ \a 15 \\_ \_ 15 \\_ \_ 16 % % 16 % a 16 % aa 16 % x 16 % \ 16 % \% 16 % \% 16 % \a 16 % \aa 16 % \\% 16 % \\% 16 % \\_ 16 % \\_ 16 % \_ 16 % \_ 16 % _ 17 \% % 18 \% % 19 \\% \ 19 \\% \% 19 \\% \% 19 \\% \a 19 \\% \aa 19 \\% \\% 19 \\% \\% 19 \\% \\_ 19 \\% \\_ 19 \\% \_ 19 \\% \_ 20 \\% \ 20 \\% \% 20 \\% \% 20 \\% \a 20 \\% \aa 20 \\% \\% 20 \\% \\% 20 \\% \\_ 20 \\% \\_ 20 \\% \_ 20 \\% \_ DROP TABLE t1; SET @@SQL_MODE='NO_BACKSLASH_ESCAPES'; show local variables like 'SQL_MODE'; Variable_name Value sql_mode NO_BACKSLASH_ESCAPES CREATE TABLE t1 (p int not null auto_increment, a varchar(20), primary key(p)); INSERT t1 (a) VALUES ('\\'), ('\n'), ('\b'), ('\r'), ('\t'), ('\x'), ('\a'), ('\aa'), ('\\a'), ('\\aa'), ('_'), ('\_'), ('\\_'), ('\\\_'), ('\\\\_'), ('%'), ('\%'), ('\\%'), ('\\\%'), ('\\\\%') ; SELECT p, hex(a) FROM t1; p hex(a) 1 5C5C 2 5C6E 3 5C62 4 5C72 5 5C74 6 5C78 7 5C61 8 5C6161 9 5C5C61 10 5C5C6161 11 5F 12 5C5F 13 5C5C5F 14 5C5C5C5F 15 5C5C5C5C5F 16 25 17 5C25 18 5C5C25 19 5C5C5C25 20 5C5C5C5C25 delete from t1 where a in ('\n','\r','\t', '\b'); select masks.p, masks.a as mask, examples.a as example from t1 as masks left join t1 as examples on examples.a LIKE masks.a order by masks.p, example; p mask example 1 \\ \\ 6 \x \x 7 \a \a 8 \aa \aa 9 \\a \\a 10 \\aa \\aa 11 _ % 11 _ _ 12 \_ \% 12 \_ \a 12 \_ \x 12 \_ \\ 12 \_ \_ 13 \\_ \\% 13 \\_ \\a 13 \\_ \\_ 14 \\\_ \\\% 14 \\\_ \\\_ 15 \\\\_ \\\\% 15 \\\\_ \\\\_ 16 % % 16 % \% 16 % \a 16 % \aa 16 % \x 16 % \\ 16 % \\% 16 % \\a 16 % \\aa 16 % \\\% 16 % \\\\% 16 % \\\\_ 16 % \\\_ 16 % \\_ 16 % \_ 16 % _ 17 \% \% 17 \% \a 17 \% \aa 17 \% \x 17 \% \\ 17 \% \\% 17 \% \\a 17 \% \\aa 17 \% \\\% 17 \% \\\\% 17 \% \\\\_ 17 \% \\\_ 17 \% \\_ 17 \% \_ 18 \\% \\ 18 \\% \\% 18 \\% \\a 18 \\% \\aa 18 \\% \\\% 18 \\% \\\\% 18 \\% \\\\_ 18 \\% \\\_ 18 \\% \\_ 19 \\\% \\\% 19 \\\% \\\\% 19 \\\% \\\\_ 19 \\\% \\\_ 20 \\\\% \\\\% 20 \\\\% \\\\_ DROP TABLE t1; SET @@SQL_MODE='NO_BACKSLASH_ESCAPES'; SELECT 'a\\b', 'a\\\"b', 'a''\\b', 'a''\\\"b'; a\\b a\\\"b a'\\b a'\\\"b a\\b a\\\"b a'\\b a'\\\"b SELECT "a\\b", "a\\\'b", "a""\\b", "a""\\\'b"; a\\b a\\\'b a"\\b a"\\\'b a\\b a\\\'b a"\\b a"\\\'b SET @@SQL_MODE=''; SELECT 'a\\b', 'a\\\"b', 'a''\\b', 'a''\\\"b'; a\b a\"b a'\b a'\"b a\b a\"b a'\b a'\"b SELECT "a\\b", "a\\\'b", "a""\\b", "a""\\\'b"; a\b a\'b a"\b a"\'b a\b a\'b a"\b a"\'b SET @@SQL_MODE=''; create function `foo` () returns int return 5; show create function `foo`; Function sql_mode Create Function character_set_client collation_connection Database Collation foo CREATE DEFINER=`root`@`localhost` FUNCTION `foo`() RETURNS int(11) return 5 latin1 latin1_swedish_ci latin1_swedish_ci SET @@SQL_MODE='ANSI_QUOTES'; show create function `foo`; Function sql_mode Create Function character_set_client collation_connection Database Collation foo CREATE DEFINER=`root`@`localhost` FUNCTION `foo`() RETURNS int(11) return 5 latin1 latin1_swedish_ci latin1_swedish_ci drop function `foo`; create function `foo` () returns int return 5; show create function `foo`; Function sql_mode Create Function character_set_client collation_connection Database Collation foo ANSI_QUOTES CREATE DEFINER="root"@"localhost" FUNCTION "foo"() RETURNS int(11) return 5 latin1 latin1_swedish_ci latin1_swedish_ci SET @@SQL_MODE=''; show create function `foo`; Function sql_mode Create Function character_set_client collation_connection Database Collation foo ANSI_QUOTES CREATE DEFINER="root"@"localhost" FUNCTION "foo"() RETURNS int(11) return 5 latin1 latin1_swedish_ci latin1_swedish_ci drop function `foo`; SET @@SQL_MODE=''; create table t1 (a int); create table t2 (a int); create view v1 as select a from t1; 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` latin1 latin1_swedish_ci SET @@SQL_MODE='ANSI_QUOTES'; 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" latin1 latin1_swedish_ci create view v2 as select a from t2 where a in (select a from v1); drop view v2, v1; drop table t1, t2; select @@sql_mode; @@sql_mode ANSI_QUOTES set sql_mode=2097152; select @@sql_mode; @@sql_mode STRICT_TRANS_TABLES set sql_mode=4194304; select @@sql_mode; @@sql_mode STRICT_ALL_TABLES set sql_mode=16384+(65536*4); select @@sql_mode; @@sql_mode REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_TABLE_OPTIONS,ANSI set sql_mode=2147483648*2*2*2; ERROR 42000: Variable 'sql_mode' can't be set to the value of '17179869184' select @@sql_mode; @@sql_mode REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_TABLE_OPTIONS,ANSI set sql_mode=PAD_CHAR_TO_FULL_LENGTH; create table t1 (a int auto_increment primary key, b char(5)); insert into t1 (b) values('a'),('b\t'),('c '); select concat('x',b,'x') from t1; concat('x',b,'x') xa x xb x xc x set sql_mode=0; select concat('x',b,'x') from t1; concat('x',b,'x') xax xb x xcx drop table t1; SET @@SQL_MODE=@OLD_SQL_MODE; create user mysqltest_32753@localhost; connection default; set @OLD_SQL_MODE=@@SESSION.SQL_MODE; set session sql_mode='PAD_CHAR_TO_FULL_LENGTH'; flush privileges; connect user_32753,localhost,mysqltest_32753,,test,$MASTER_MYPORT,$MASTER_MYSOCK; select current_user(); current_user() mysqltest_32753@localhost connection default; set session sql_mode=@OLD_SQL_MODE; flush privileges; disconnect user_32753; connection default; drop user mysqltest_32753@localhost; SET @org_mode=@@sql_mode; SET @@sql_mode='traditional'; SELECT @@sql_mode LIKE '%NO_ENGINE_SUBSTITUTION%'; @@sql_mode LIKE '%NO_ENGINE_SUBSTITUTION%' 1 SET sql_mode=@org_mode; DROP TABLE IF EXISTS t1,t2; CREATE USER 'user_PCTFL'@'localhost' identified by 'PWD'; CREATE USER 'user_no_PCTFL'@'localhost' identified by 'PWD'; CREATE TABLE t1 (f1 BIGINT); CREATE TABLE t2 (f1 CHAR(3) NOT NULL, f2 CHAR(20)); GRANT ALL ON t1 TO 'user_PCTFL'@'localhost','user_no_PCTFL'@'localhost'; GRANT SELECT(f1) ON t2 TO 'user_PCTFL'@'localhost','user_no_PCTFL'@'localhost'; SET @OLD_SQL_MODE = @@SESSION.SQL_MODE; SET SESSION SQL_MODE = 'PAD_CHAR_TO_FULL_LENGTH'; DROP USER 'user_PCTFL'@'localhost'; SET SESSION SQL_MODE = @OLD_SQL_MODE; DROP USER 'user_no_PCTFL'@'localhost'; FLUSH PRIVILEGES; SELECT * FROM mysql.db WHERE Host = 'localhost' AND User LIKE 'user_%PCTFL'; Host Db User Select_priv Insert_priv Update_priv Delete_priv Create_priv Drop_priv Grant_priv References_priv Index_priv Alter_priv Create_tmp_table_priv Lock_tables_priv Create_view_priv Show_view_priv Create_routine_priv Alter_routine_priv Execute_priv Event_priv Trigger_priv Delete_history_priv SELECT * FROM mysql.tables_priv WHERE Host = 'localhost' AND User LIKE 'user_%PCTFL'; Host Db User Table_name Grantor Timestamp Table_priv Column_priv SELECT * FROM mysql.columns_priv WHERE Host = 'localhost' AND User LIKE 'user_%PCTFL'; Host Db User Table_name Column_name Timestamp Column_priv DROP TABLE t1; DROP TABLE t2; # # Test for Bug#12601974 - STORED PROCEDURE SQL_MODE=NO_BACKSLASH_ESCAPES # IGNORED AND BREAKS REPLICATION # DROP TABLE IF EXISTS test_table; DROP FUNCTION IF EXISTS test_function; CREATE TABLE test_table (c1 CHAR(50)); SET @org_mode=@@sql_mode; SET @@sql_mode=''; PREPARE insert_stmt FROM 'INSERT INTO test_table VALUES (?)'; PREPARE update_stmt FROM 'UPDATE test_table SET c1= ? WHERE c1= ?'; CREATE FUNCTION test_function(var CHAR(50)) RETURNS CHAR(50) BEGIN DECLARE char_val CHAR(50); SELECT c1 INTO char_val FROM test_table WHERE c1=var; RETURN char_val; END $ SET @var1='abcd\'ef'; SET @var2='abcd\"ef'; SET @var3='abcd\bef'; SET @var4='abcd\nef'; SET @var5='abcd\ref'; SET @var6='abcd\tef'; SET @var7='abcd\\ef'; SET @var8='abcd\%ef'; SET @var9='abcd\_ef'; SET @to_var1='wxyz\'ef'; SET @to_var2='wxyz\"ef'; SET @to_var3='wxyz\bef'; SET @to_var4='wxyz\nef'; SET @to_var5='wxyz\ref'; SET @to_var6='wxyz\tef'; SET @to_var7='wxyz\\ef'; SET @to_var8='wxyz\%ef'; SET @to_var9='wxyz\_ef'; # STRING LILTERAL WITH BACKSLASH IN PREPARE STATEMENT EXECUTE insert_stmt USING @var1; EXECUTE insert_stmt USING @var2; EXECUTE insert_stmt USING @var3; EXECUTE insert_stmt USING @var4; EXECUTE insert_stmt USING @var5; EXECUTE insert_stmt USING @var6; EXECUTE insert_stmt USING @var7; EXECUTE insert_stmt USING @var8; EXECUTE insert_stmt USING @var9; SELECT * FROM test_table; c1 abcd'ef abcd"ef abcdef abcd ef abcd ef abcd ef abcd\ef abcd\%ef abcd\_ef EXECUTE update_stmt USING @to_var1, @var1; EXECUTE update_stmt USING @to_var2, @var2; EXECUTE update_stmt USING @to_var3, @var3; EXECUTE update_stmt USING @to_var4, @var4; EXECUTE update_stmt USING @to_var5, @var5; EXECUTE update_stmt USING @to_var6, @var6; EXECUTE update_stmt USING @to_var7, @var7; EXECUTE update_stmt USING @to_var8, @var8; EXECUTE update_stmt USING @to_var9, @var9; SELECT * FROM test_table; c1 wxyz'ef wxyz"ef wxyzef wxyz ef wxyz ef wxyz ef wxyz\ef wxyz\%ef wxyz\_ef # END OF CASE - STRING LILTERAL WITH BACKSLASH IN PREPARE STATEMENT # STRING LILTERAL WITH BACKSLASH IN FUNCTION RETURNING STRING select test_function(@to_var1); test_function(@to_var1) wxyz'ef SELECT test_function(@to_var2); test_function(@to_var2) wxyz"ef SELECT test_function(@to_var3); test_function(@to_var3) wxyzef SELECT test_function(@to_var4); test_function(@to_var4) wxyz ef SELECT test_function(@to_var5); test_function(@to_var5) wxyz ef SELECT test_function(@to_var6); test_function(@to_var6) wxyz ef SELECT test_function(@to_var7); test_function(@to_var7) wxyz\ef SELECT test_function(@to_var8); test_function(@to_var8) wxyz\%ef SELECT test_function(@to_var9); test_function(@to_var9) wxyz\_ef # END OF CASE - STRING LILTERAL WITH BACKSLASH IN FUNCTION RETURNING STRING DELETE FROM test_table; DROP FUNCTION test_function; SET @@sql_mode='NO_BACKSLASH_ESCAPES'; CREATE FUNCTION test_function(var CHAR(50)) RETURNS CHAR(50) BEGIN DECLARE char_val CHAR(50); SELECT c1 INTO char_val FROM test_table WHERE c1=var; RETURN char_val; END $ # STRING LILTERAL WITH BACKSLASH IN PREPARE STATEMENT EXECUTE insert_stmt USING @var1; EXECUTE insert_stmt USING @var2; EXECUTE insert_stmt USING @var3; EXECUTE insert_stmt USING @var4; EXECUTE insert_stmt USING @var5; EXECUTE insert_stmt USING @var6; EXECUTE insert_stmt USING @var7; EXECUTE insert_stmt USING @var8; EXECUTE insert_stmt USING @var9; SELECT * FROM test_table; c1 abcd'ef abcd"ef abcdef abcd ef abcd ef abcd ef abcd\ef abcd\%ef abcd\_ef EXECUTE update_stmt USING @to_var1, @var1; EXECUTE update_stmt USING @to_var2, @var2; EXECUTE update_stmt USING @to_var3, @var3; EXECUTE update_stmt USING @to_var4, @var4; EXECUTE update_stmt USING @to_var5, @var5; EXECUTE update_stmt USING @to_var6, @var6; EXECUTE update_stmt USING @to_var7, @var7; EXECUTE update_stmt USING @to_var8, @var8; EXECUTE update_stmt USING @to_var9, @var9; SELECT * FROM test_table; c1 wxyz'ef wxyz"ef wxyzef wxyz ef wxyz ef wxyz ef wxyz\ef wxyz\%ef wxyz\_ef # END OF CASE - STRING LILTERAL WITH BACKSLASH IN PREPARE STATEMENT # STRING LILTERAL WITH BACKSLASH IN FUNCTION RETURNING STRING select test_function(@to_var1); test_function(@to_var1) wxyz'ef SELECT test_function(@to_var2); test_function(@to_var2) wxyz"ef SELECT test_function(@to_var3); test_function(@to_var3) wxyzef SELECT test_function(@to_var4); test_function(@to_var4) wxyz ef SELECT test_function(@to_var5); test_function(@to_var5) wxyz ef SELECT test_function(@to_var6); test_function(@to_var6) wxyz ef SELECT test_function(@to_var7); test_function(@to_var7) wxyz\ef SELECT test_function(@to_var8); test_function(@to_var8) wxyz\%ef SELECT test_function(@to_var9); test_function(@to_var9) wxyz\_ef # END OF CASE - STRING LILTERAL WITH BACKSLASH IN FUNCTION RETURNING STRING DROP TABLE test_table; DROP FUNCTION test_function; SET @@sql_mode= @org_mode; #End of Test for Bug#12601974 # # MDEV-11848 Automatic statement repreparation changes query semantics # SET sql_mode=DEFAULT; CREATE OR REPLACE TABLE t1 (a TEXT); PREPARE stmt FROM 'INSERT INTO t1 (a) VALUES (2||3)'; EXECUTE stmt; SET sql_mode=ORACLE; EXECUTE stmt; ALTER TABLE t1 ADD b INT; EXECUTE stmt; SELECT * FROM t1; a b 1 NULL 1 NULL 1 NULL DROP TABLE t1; # # MDEV-12390 Wrong error line numbers reported with sql_mode=IGNORE_SPACE # SET sql_mode=IGNORE_SPACE; CREATE PROCEDURE p1() BEGIN SELECT 1+1; syntax error; END; $$ ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'error; END' at line 4 SET sql_mode=DEFAULT; CREATE PROCEDURE p1() BEGIN SELECT 1+1; syntax error; END; $$ ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'error; END' at line 4