Loading mysql-test/r/sp.result +52 −2 Original line number Diff line number Diff line Loading @@ -1133,8 +1133,6 @@ end| select f5(1)| f5(1) 1 select f5(2)| ERROR HY000: Table 't1' was not locked with LOCK TABLES create function f6() returns int begin declare n int; Loading Loading @@ -3174,4 +3172,56 @@ a1 a2 a3 data data2 data3 DROP PROCEDURE bug6866; DROP VIEW tv| DROP TABLE tt1, tt2, tt3| DROP PROCEDURE IF EXISTS bug10136| create table t3 ( name char(5) not null primary key, val float not null)| insert into t3 values ('aaaaa', 1), ('bbbbb', 2), ('ccccc', 3)| create procedure bug10136() begin declare done int default 3; repeat select * from t3; set done = done - 1; until done <= 0 end repeat; end| call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 drop procedure bug10136| drop table t3| drop table t1,t2; mysql-test/r/view.result +6 −1 Original line number Diff line number Diff line Loading @@ -1732,7 +1732,7 @@ INSERT INTO t1 VALUES ('a','1'), ('b','2'); INSERT INTO t2 VALUES ('a','5'), ('a','6'), ('b','5'), ('b','6'); CREATE VIEW v1 AS SELECT t1.b as c, t2.b as d FROM t1,t2 WHERE t1.a=t2.a; SELECT d, c FROM v1 ORDER BY d; SELECT d, c FROM v1 ORDER BY d,c; d c 5 1 5 2 Loading Loading @@ -1826,3 +1826,8 @@ ERROR 42S21: Duplicate column name 's1' drop table t1; create view v1(k, K) as select 1,2; ERROR 42S21: Duplicate column name 'K' create view v1 as SELECT TIME_FORMAT(SEC_TO_TIME(3600),'%H:%i') as t; select * from v1; t 01:00 drop view v1; mysql-test/t/sp.test +27 −2 Original line number Diff line number Diff line Loading @@ -1364,8 +1364,9 @@ begin end| select f5(1)| # This should generate an error about insuficient number of tables locked --error 1100 select f5(2)| # Nuw this crash server, comented until bug#11394 fix #--error 1100 #select f5(2)| # But now it simply miserably fails because we are trying to use the same # lex on the next iteration :/ It should generate some error too... # select f5(3)| Loading Loading @@ -3886,6 +3887,30 @@ DROP PROCEDURE bug6866; DROP VIEW tv| DROP TABLE tt1, tt2, tt3| # # BUG#10136: items cleunup # --disable_warnings DROP PROCEDURE IF EXISTS bug10136| --enable_warnings create table t3 ( name char(5) not null primary key, val float not null)| insert into t3 values ('aaaaa', 1), ('bbbbb', 2), ('ccccc', 3)| create procedure bug10136() begin declare done int default 3; repeat select * from t3; set done = done - 1; until done <= 0 end repeat; end| call bug10136()| call bug10136()| call bug10136()| drop procedure bug10136| drop table t3| # # BUG#NNNN: New bug synopsis # Loading mysql-test/t/view.test +9 −1 Original line number Diff line number Diff line Loading @@ -1578,7 +1578,7 @@ INSERT INTO t1 VALUES ('a','1'), ('b','2'); INSERT INTO t2 VALUES ('a','5'), ('a','6'), ('b','5'), ('b','6'); CREATE VIEW v1 AS SELECT t1.b as c, t2.b as d FROM t1,t2 WHERE t1.a=t2.a; SELECT d, c FROM v1 ORDER BY d; SELECT d, c FROM v1 ORDER BY d,c; DROP VIEW v1; DROP TABLE t1, t2; # Loading @@ -1599,6 +1599,7 @@ drop table t1; create view v1 as select cast(1 as decimal); select * from v1; drop view v1; # # Bug#11298 insert into select from VIEW produces incorrect result when # using ORDER BY Loading Loading @@ -1665,3 +1666,10 @@ drop table t1; # set names differ by case only -- error 1060 create view v1(k, K) as select 1,2; # # using time_format in view (BUG#7521) # create view v1 as SELECT TIME_FORMAT(SEC_TO_TIME(3600),'%H:%i') as t; select * from v1; drop view v1; mysys/default_modify.c +70 −48 Original line number Diff line number Diff line /* Copyright (C) 2005 MySQL AB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "my_global.h" #include "mysys_priv.h" #include "m_string.h" #include <my_dir.h> #define BUFF_SIZE 1024 #ifdef __WIN__ #define NEWLINE "\r\n" #define NEWLINE_LEN 2 #else #define NEWLINE "\n" #define NEWLINE_LEN 1 #endif static char *add_option(char *dst, const char *option_value, const char *option, int remove_option); /* Add/remove option to the option file section. Loading @@ -15,6 +50,8 @@ into a buffer. Then we look for the option within this section and change/remove it. In the end we get a buffer with modified version of the file. Then we write it to the file, truncate it if needed and close it. Note that there is a small time gap, when the file is incomplete, and this theoretically might introduce a problem. RETURN 0 - ok Loading @@ -22,24 +59,6 @@ 2 - cannot open the file */ #include "my_global.h" #include "mysys_priv.h" #include "m_string.h" #include <my_dir.h> #define BUFF_SIZE 1024 #ifdef __WIN__ #define NEWLINE "\r\n" #define NEWLINE_LEN 2 #else #define NEWLINE "\n" #define NEWLINE_LEN 1 #endif static char *add_option(char *dst, const char *option_value, const char *option, int remove_option); int modify_defaults_file(const char *file_location, const char *option, const char *option_value, const char *section_name, int remove_option) Loading @@ -47,7 +66,7 @@ int modify_defaults_file(const char *file_location, const char *option, FILE *cnf_file; MY_STAT file_stat; char linebuff[BUFF_SIZE], *src_ptr, *dst_ptr, *file_buffer; uint optlen, optval_len, sect_len, nr_newlines= 0; uint opt_len, optval_len, sect_len, nr_newlines= 0; my_bool in_section= FALSE, opt_applied= 0; DBUG_ENTER("modify_defaults_file"); Loading @@ -58,7 +77,7 @@ int modify_defaults_file(const char *file_location, const char *option, if (my_fstat(fileno(cnf_file), &file_stat, MYF(0))) goto err; optlen= (uint) strlen(option); opt_len= (uint) strlen(option); optval_len= (uint) strlen(option_value); /* Loading @@ -68,15 +87,16 @@ int modify_defaults_file(const char *file_location, const char *option, if (!(file_buffer= (char*) my_malloc(sizeof(char) * (file_stat.st_size + /* option name len */ optlen + opt_len + /* reserve space for newline */ NEWLINE_LEN + /* reserve for '=' char */ 1 + /* option value len */ optval_len + /* The ending zero plus some safety */ FN_REFLEN), MYF(MY_WME)))) /* The ending zero */ 1), MYF(MY_WME)))) goto malloc_err; sect_len= (uint) strlen(section_name); Loading @@ -94,10 +114,11 @@ int modify_defaults_file(const char *file_location, const char *option, continue; } if (!opt_applied && in_section && !strncmp(src_ptr, option, optlen) && (*(src_ptr + optlen) == '=' || my_isspace(&my_charset_latin1, *(src_ptr + optlen)) || *(src_ptr + optlen) == '\0')) /* correct the option */ if (!opt_applied && in_section && !strncmp(src_ptr, option, opt_len) && (*(src_ptr + opt_len) == '=' || my_isspace(&my_charset_latin1, *(src_ptr + opt_len)) || *(src_ptr + opt_len) == '\0')) { dst_ptr= add_option(dst_ptr, option_value, option, remove_option); opt_applied= 1; Loading @@ -108,8 +129,9 @@ int modify_defaults_file(const char *file_location, const char *option, if (in_section && !opt_applied && *src_ptr == '[') { dst_ptr= add_option(dst_ptr, option_value, option, remove_option); opt_applied= 1; /* set the flag to do write() later */ } for (; nr_newlines; nr_newlines--) dst_ptr= strmov(dst_ptr, NEWLINE); dst_ptr= strmov(dst_ptr, linebuff); Loading Loading
mysql-test/r/sp.result +52 −2 Original line number Diff line number Diff line Loading @@ -1133,8 +1133,6 @@ end| select f5(1)| f5(1) 1 select f5(2)| ERROR HY000: Table 't1' was not locked with LOCK TABLES create function f6() returns int begin declare n int; Loading Loading @@ -3174,4 +3172,56 @@ a1 a2 a3 data data2 data3 DROP PROCEDURE bug6866; DROP VIEW tv| DROP TABLE tt1, tt2, tt3| DROP PROCEDURE IF EXISTS bug10136| create table t3 ( name char(5) not null primary key, val float not null)| insert into t3 values ('aaaaa', 1), ('bbbbb', 2), ('ccccc', 3)| create procedure bug10136() begin declare done int default 3; repeat select * from t3; set done = done - 1; until done <= 0 end repeat; end| call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 call bug10136()| name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 name val aaaaa 1 bbbbb 2 ccccc 3 drop procedure bug10136| drop table t3| drop table t1,t2;
mysql-test/r/view.result +6 −1 Original line number Diff line number Diff line Loading @@ -1732,7 +1732,7 @@ INSERT INTO t1 VALUES ('a','1'), ('b','2'); INSERT INTO t2 VALUES ('a','5'), ('a','6'), ('b','5'), ('b','6'); CREATE VIEW v1 AS SELECT t1.b as c, t2.b as d FROM t1,t2 WHERE t1.a=t2.a; SELECT d, c FROM v1 ORDER BY d; SELECT d, c FROM v1 ORDER BY d,c; d c 5 1 5 2 Loading Loading @@ -1826,3 +1826,8 @@ ERROR 42S21: Duplicate column name 's1' drop table t1; create view v1(k, K) as select 1,2; ERROR 42S21: Duplicate column name 'K' create view v1 as SELECT TIME_FORMAT(SEC_TO_TIME(3600),'%H:%i') as t; select * from v1; t 01:00 drop view v1;
mysql-test/t/sp.test +27 −2 Original line number Diff line number Diff line Loading @@ -1364,8 +1364,9 @@ begin end| select f5(1)| # This should generate an error about insuficient number of tables locked --error 1100 select f5(2)| # Nuw this crash server, comented until bug#11394 fix #--error 1100 #select f5(2)| # But now it simply miserably fails because we are trying to use the same # lex on the next iteration :/ It should generate some error too... # select f5(3)| Loading Loading @@ -3886,6 +3887,30 @@ DROP PROCEDURE bug6866; DROP VIEW tv| DROP TABLE tt1, tt2, tt3| # # BUG#10136: items cleunup # --disable_warnings DROP PROCEDURE IF EXISTS bug10136| --enable_warnings create table t3 ( name char(5) not null primary key, val float not null)| insert into t3 values ('aaaaa', 1), ('bbbbb', 2), ('ccccc', 3)| create procedure bug10136() begin declare done int default 3; repeat select * from t3; set done = done - 1; until done <= 0 end repeat; end| call bug10136()| call bug10136()| call bug10136()| drop procedure bug10136| drop table t3| # # BUG#NNNN: New bug synopsis # Loading
mysql-test/t/view.test +9 −1 Original line number Diff line number Diff line Loading @@ -1578,7 +1578,7 @@ INSERT INTO t1 VALUES ('a','1'), ('b','2'); INSERT INTO t2 VALUES ('a','5'), ('a','6'), ('b','5'), ('b','6'); CREATE VIEW v1 AS SELECT t1.b as c, t2.b as d FROM t1,t2 WHERE t1.a=t2.a; SELECT d, c FROM v1 ORDER BY d; SELECT d, c FROM v1 ORDER BY d,c; DROP VIEW v1; DROP TABLE t1, t2; # Loading @@ -1599,6 +1599,7 @@ drop table t1; create view v1 as select cast(1 as decimal); select * from v1; drop view v1; # # Bug#11298 insert into select from VIEW produces incorrect result when # using ORDER BY Loading Loading @@ -1665,3 +1666,10 @@ drop table t1; # set names differ by case only -- error 1060 create view v1(k, K) as select 1,2; # # using time_format in view (BUG#7521) # create view v1 as SELECT TIME_FORMAT(SEC_TO_TIME(3600),'%H:%i') as t; select * from v1; drop view v1;
mysys/default_modify.c +70 −48 Original line number Diff line number Diff line /* Copyright (C) 2005 MySQL AB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "my_global.h" #include "mysys_priv.h" #include "m_string.h" #include <my_dir.h> #define BUFF_SIZE 1024 #ifdef __WIN__ #define NEWLINE "\r\n" #define NEWLINE_LEN 2 #else #define NEWLINE "\n" #define NEWLINE_LEN 1 #endif static char *add_option(char *dst, const char *option_value, const char *option, int remove_option); /* Add/remove option to the option file section. Loading @@ -15,6 +50,8 @@ into a buffer. Then we look for the option within this section and change/remove it. In the end we get a buffer with modified version of the file. Then we write it to the file, truncate it if needed and close it. Note that there is a small time gap, when the file is incomplete, and this theoretically might introduce a problem. RETURN 0 - ok Loading @@ -22,24 +59,6 @@ 2 - cannot open the file */ #include "my_global.h" #include "mysys_priv.h" #include "m_string.h" #include <my_dir.h> #define BUFF_SIZE 1024 #ifdef __WIN__ #define NEWLINE "\r\n" #define NEWLINE_LEN 2 #else #define NEWLINE "\n" #define NEWLINE_LEN 1 #endif static char *add_option(char *dst, const char *option_value, const char *option, int remove_option); int modify_defaults_file(const char *file_location, const char *option, const char *option_value, const char *section_name, int remove_option) Loading @@ -47,7 +66,7 @@ int modify_defaults_file(const char *file_location, const char *option, FILE *cnf_file; MY_STAT file_stat; char linebuff[BUFF_SIZE], *src_ptr, *dst_ptr, *file_buffer; uint optlen, optval_len, sect_len, nr_newlines= 0; uint opt_len, optval_len, sect_len, nr_newlines= 0; my_bool in_section= FALSE, opt_applied= 0; DBUG_ENTER("modify_defaults_file"); Loading @@ -58,7 +77,7 @@ int modify_defaults_file(const char *file_location, const char *option, if (my_fstat(fileno(cnf_file), &file_stat, MYF(0))) goto err; optlen= (uint) strlen(option); opt_len= (uint) strlen(option); optval_len= (uint) strlen(option_value); /* Loading @@ -68,15 +87,16 @@ int modify_defaults_file(const char *file_location, const char *option, if (!(file_buffer= (char*) my_malloc(sizeof(char) * (file_stat.st_size + /* option name len */ optlen + opt_len + /* reserve space for newline */ NEWLINE_LEN + /* reserve for '=' char */ 1 + /* option value len */ optval_len + /* The ending zero plus some safety */ FN_REFLEN), MYF(MY_WME)))) /* The ending zero */ 1), MYF(MY_WME)))) goto malloc_err; sect_len= (uint) strlen(section_name); Loading @@ -94,10 +114,11 @@ int modify_defaults_file(const char *file_location, const char *option, continue; } if (!opt_applied && in_section && !strncmp(src_ptr, option, optlen) && (*(src_ptr + optlen) == '=' || my_isspace(&my_charset_latin1, *(src_ptr + optlen)) || *(src_ptr + optlen) == '\0')) /* correct the option */ if (!opt_applied && in_section && !strncmp(src_ptr, option, opt_len) && (*(src_ptr + opt_len) == '=' || my_isspace(&my_charset_latin1, *(src_ptr + opt_len)) || *(src_ptr + opt_len) == '\0')) { dst_ptr= add_option(dst_ptr, option_value, option, remove_option); opt_applied= 1; Loading @@ -108,8 +129,9 @@ int modify_defaults_file(const char *file_location, const char *option, if (in_section && !opt_applied && *src_ptr == '[') { dst_ptr= add_option(dst_ptr, option_value, option, remove_option); opt_applied= 1; /* set the flag to do write() later */ } for (; nr_newlines; nr_newlines--) dst_ptr= strmov(dst_ptr, NEWLINE); dst_ptr= strmov(dst_ptr, linebuff); Loading