mirror of
https://github.com/MariaDB/server.git
synced 2025-01-30 10:31:54 +01:00
f3d5127f4d
Analysis: ------------------------------- According to the Manual (http://dev.mysql.com/doc/refman/5.1/en/identifier-case-sensitivity.html): "Column, index, stored routine, and event names are not case sensitive on any platform, nor are column aliases." In other words, 'lower_case_table_names' does not affect the behaviour of those identifiers. On the other hand, trigger names are case sensitive on some platforms, and case insensitive on others. 'lower_case_table_names' does not affect the behaviour of trigger names either. The bug was that SHOW statements did case sensitive comparison for stored procedure / stored function / event names. Fix: Modified the code so that comparison in case insensitive for routines and events for "SHOW" operation. As part of this commit, only fixing the test failures due to the actual code fix.
304 lines
8.2 KiB
Text
304 lines
8.2 KiB
Text
set @old_concurrent_insert= @@global.concurrent_insert;
|
|
set @@global.concurrent_insert= 0;
|
|
drop table if exists t1,t3;
|
|
drop procedure if exists bug4902|
|
|
create procedure bug4902()
|
|
begin
|
|
show grants for 'root'@'localhost';
|
|
end|
|
|
call bug4902()|
|
|
Grants for root@localhost
|
|
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
|
|
call bug4902()|
|
|
Grants for root@localhost
|
|
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
|
|
drop procedure bug4902|
|
|
drop procedure if exists bug4902_2|
|
|
create procedure bug4902_2()
|
|
begin
|
|
show processlist;
|
|
end|
|
|
call bug4902_2()|
|
|
show warnings|
|
|
Level Code Message
|
|
call bug4902_2()|
|
|
show warnings|
|
|
Level Code Message
|
|
drop procedure bug4902_2|
|
|
drop table if exists t1|
|
|
create table t1 (
|
|
id char(16) not null default '',
|
|
data int not null
|
|
)|
|
|
drop procedure if exists bug3583|
|
|
drop procedure if exists bug3583|
|
|
create procedure bug3583()
|
|
begin
|
|
declare c int;
|
|
select * from t1;
|
|
select count(*) into c from t1;
|
|
select c;
|
|
end|
|
|
insert into t1 values ("x", 3), ("y", 5)|
|
|
set @x = @@query_cache_size|
|
|
set global query_cache_size = 10*1024*1024|
|
|
flush status|
|
|
flush query cache|
|
|
show status like 'Qcache_hits'|
|
|
Variable_name Value
|
|
Qcache_hits 0
|
|
call bug3583()|
|
|
id data
|
|
x 3
|
|
y 5
|
|
c
|
|
2
|
|
show status like 'Qcache_hits'|
|
|
Variable_name Value
|
|
Qcache_hits 0
|
|
call bug3583()|
|
|
id data
|
|
x 3
|
|
y 5
|
|
c
|
|
2
|
|
call bug3583()|
|
|
id data
|
|
x 3
|
|
y 5
|
|
c
|
|
2
|
|
show status like 'Qcache_hits'|
|
|
Variable_name Value
|
|
Qcache_hits 2
|
|
set global query_cache_size = @x|
|
|
flush status|
|
|
flush query cache|
|
|
delete from t1|
|
|
drop procedure bug3583|
|
|
drop table t1|
|
|
drop procedure if exists bug6807|
|
|
create procedure bug6807()
|
|
begin
|
|
declare id int;
|
|
set id = connection_id();
|
|
kill query id;
|
|
select 'Not reached';
|
|
end|
|
|
call bug6807()|
|
|
ERROR 70100: Query execution was interrupted
|
|
call bug6807()|
|
|
ERROR 70100: Query execution was interrupted
|
|
drop procedure bug6807|
|
|
drop function if exists bug10100f|
|
|
drop procedure if exists bug10100p|
|
|
drop procedure if exists bug10100t|
|
|
drop procedure if exists bug10100pt|
|
|
drop procedure if exists bug10100pv|
|
|
drop procedure if exists bug10100pd|
|
|
drop procedure if exists bug10100pc|
|
|
create function bug10100f(prm int) returns int
|
|
begin
|
|
if prm > 1 then
|
|
return prm * bug10100f(prm - 1);
|
|
end if;
|
|
return 1;
|
|
end|
|
|
create procedure bug10100p(prm int, inout res int)
|
|
begin
|
|
set res = res * prm;
|
|
if prm > 1 then
|
|
call bug10100p(prm - 1, res);
|
|
end if;
|
|
end|
|
|
create procedure bug10100t(prm int)
|
|
begin
|
|
declare res int;
|
|
set res = 1;
|
|
call bug10100p(prm, res);
|
|
select res;
|
|
end|
|
|
create table t3 (a int)|
|
|
insert into t3 values (0)|
|
|
create view v1 as select a from t3;
|
|
create procedure bug10100pt(level int, lim int)
|
|
begin
|
|
if level < lim then
|
|
update t3 set a=level;
|
|
FLUSH TABLES;
|
|
call bug10100pt(level+1, lim);
|
|
else
|
|
select * from t3;
|
|
end if;
|
|
end|
|
|
create procedure bug10100pv(level int, lim int)
|
|
begin
|
|
if level < lim then
|
|
update v1 set a=level;
|
|
FLUSH TABLES;
|
|
call bug10100pv(level+1, lim);
|
|
else
|
|
select * from v1;
|
|
end if;
|
|
end|
|
|
prepare stmt2 from "select * from t3;";
|
|
create procedure bug10100pd(level int, lim int)
|
|
begin
|
|
if level < lim then
|
|
select level;
|
|
prepare stmt1 from "update t3 set a=a+2";
|
|
execute stmt1;
|
|
FLUSH TABLES;
|
|
execute stmt1;
|
|
FLUSH TABLES;
|
|
execute stmt1;
|
|
FLUSH TABLES;
|
|
deallocate prepare stmt1;
|
|
execute stmt2;
|
|
select * from t3;
|
|
call bug10100pd(level+1, lim);
|
|
else
|
|
execute stmt2;
|
|
end if;
|
|
end|
|
|
create procedure bug10100pc(level int, lim int)
|
|
begin
|
|
declare lv int;
|
|
declare c cursor for select a from t3;
|
|
open c;
|
|
if level < lim then
|
|
select level;
|
|
fetch c into lv;
|
|
select lv;
|
|
update t3 set a=level+lv;
|
|
FLUSH TABLES;
|
|
call bug10100pc(level+1, lim);
|
|
else
|
|
select * from t3;
|
|
end if;
|
|
close c;
|
|
end|
|
|
set @@max_sp_recursion_depth=255|
|
|
set @var=1|
|
|
call bug10100p(255, @var)|
|
|
call bug10100pt(1,255)|
|
|
call bug10100pv(1,255)|
|
|
call bug10100pd(1,255)|
|
|
call bug10100pc(1,255)|
|
|
set @@max_sp_recursion_depth=0|
|
|
deallocate prepare stmt2|
|
|
drop function bug10100f|
|
|
drop procedure bug10100p|
|
|
drop procedure bug10100t|
|
|
drop procedure bug10100pt|
|
|
drop procedure bug10100pv|
|
|
drop procedure bug10100pd|
|
|
drop procedure bug10100pc|
|
|
drop view v1|
|
|
drop table t3|
|
|
drop procedure if exists bug15298_1;
|
|
drop procedure if exists bug15298_2;
|
|
grant all privileges on test.* to 'mysqltest_1'@'localhost';
|
|
create procedure 15298_1 () sql security definer show grants for current_user;
|
|
create procedure 15298_2 () sql security definer show grants;
|
|
call 15298_1();
|
|
Grants for root@localhost
|
|
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
|
|
call 15298_2();
|
|
Grants for root@localhost
|
|
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
|
|
drop user mysqltest_1@localhost;
|
|
drop procedure 15298_1;
|
|
drop procedure 15298_2;
|
|
drop table if exists t1;
|
|
drop procedure if exists p1;
|
|
create table t1 (value varchar(15));
|
|
create procedure p1() update t1 set value='updated' where value='old';
|
|
call p1();
|
|
insert into t1 (value) values ("old");
|
|
select get_lock('b26162',120);
|
|
get_lock('b26162',120)
|
|
1
|
|
select 'rl_acquirer', value from t1 where get_lock('b26162',120);;
|
|
set session low_priority_updates=on;
|
|
call p1();;
|
|
select 'rl_contender', value from t1;
|
|
rl_contender value
|
|
rl_contender old
|
|
select release_lock('b26162');
|
|
release_lock('b26162')
|
|
1
|
|
rl_acquirer value
|
|
rl_acquirer old
|
|
drop procedure p1;
|
|
drop table t1;
|
|
set session low_priority_updates=default;
|
|
INSERT INTO mysql.user (Host, User, Password, Select_priv, Insert_priv, Update_priv,
|
|
Delete_priv, Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv, File_priv,
|
|
Grant_priv, References_priv, Index_priv, Alter_priv, Show_db_priv, Super_priv,
|
|
Create_tmp_table_priv, Lock_tables_priv, Execute_priv, Repl_slave_priv, Repl_client_priv,
|
|
Create_view_priv, Show_view_priv, Create_routine_priv, Alter_routine_priv,
|
|
Create_user_priv, ssl_type, ssl_cipher, x509_issuer, x509_subject, max_questions,
|
|
max_updates, max_connections, max_user_connections)
|
|
VALUES('%', 'mysqltest_1', password(''), 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'N', 'N', 'N',
|
|
'N', 'N', 'N', 'Y', 'Y', 'N', 'N', 'Y', 'Y', 'N', 'N', 'N', 'N', 'N', 'Y', 'Y', 'N', '',
|
|
'', '', '', '0', '0', '0', '0');
|
|
FLUSH PRIVILEGES;
|
|
CREATE PROCEDURE p1(i INT) BEGIN END;
|
|
DROP PROCEDURE p1;
|
|
DELETE FROM mysql.user WHERE User='mysqltest_1';
|
|
FLUSH PRIVILEGES;
|
|
set @@global.concurrent_insert= @old_concurrent_insert;
|
|
#
|
|
# Bug#44521 Prepared Statement: CALL p() - crashes: `! thd->main_da.is_sent' failed et.al.
|
|
#
|
|
SELECT GET_LOCK('Bug44521', 0);
|
|
GET_LOCK('Bug44521', 0)
|
|
1
|
|
** Connection con1
|
|
CREATE PROCEDURE p()
|
|
BEGIN
|
|
SELECT 1;
|
|
SELECT GET_LOCK('Bug44521', 100);
|
|
SELECT 2;
|
|
END$
|
|
CALL p();;
|
|
** Default connection
|
|
SELECT RELEASE_LOCK('Bug44521');
|
|
RELEASE_LOCK('Bug44521')
|
|
1
|
|
DROP PROCEDURE p;
|
|
CREATE TABLE t1(a int);
|
|
INSERT INTO t1 VALUES (1);
|
|
CREATE FUNCTION f1 (inp TEXT) RETURNS INT NO SQL RETURN sleep(60);
|
|
CREATE VIEW v1 AS SELECT f1('a') FROM t1;
|
|
SELECT * FROM v1;;
|
|
SELECT * FROM v1;
|
|
ERROR 70100: Query execution was interrupted
|
|
ERROR 70100: Query execution was interrupted
|
|
DROP VIEW v1;
|
|
DROP TABLE t1;
|
|
DROP FUNCTION f1;
|
|
#
|
|
# Bug#11763507 - 56224: FUNCTION NAME IS CASE-SENSITIVE
|
|
#
|
|
SET @@SQL_MODE = '';
|
|
CREATE EVENT teste_bug11763507 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR
|
|
DO SELECT 1 $
|
|
SHOW EVENTS LIKE 'teste_bug11763507';
|
|
Db Name Definer Time zone Type Execute at Interval value Interval field Starts Ends Status Originator character_set_client collation_connection Database Collation
|
|
test teste_bug11763507 root@localhost SYSTEM ONE TIME # # # # NULL ENABLED 1 latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SHOW EVENTS LIKE 'TESTE_bug11763507';
|
|
Db Name Definer Time zone Type Execute at Interval value Interval field Starts Ends Status Originator character_set_client collation_connection Database Collation
|
|
test teste_bug11763507 root@localhost SYSTEM ONE TIME # # # # NULL ENABLED 1 latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SHOW CREATE EVENT teste_bug11763507;
|
|
Event sql_mode time_zone Create Event character_set_client collation_connection Database Collation
|
|
teste_bug11763507 SYSTEM # latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SHOW CREATE EVENT TESTE_bug11763507;
|
|
Event sql_mode time_zone Create Event character_set_client collation_connection Database Collation
|
|
teste_bug11763507 SYSTEM # latin1 latin1_swedish_ci latin1_swedish_ci
|
|
DROP EVENT teste_bug11763507;
|
|
#END OF BUG#11763507 test.
|
|
# ------------------------------------------------------------------
|
|
# -- End of 5.1 tests
|
|
# ------------------------------------------------------------------
|