Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
56a59f98
Commit
56a59f98
authored
Dec 06, 2005
by
ingo@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/mydev/mysql-5.0
into mysql.com:/home/mydev/mysql-5.0-bug10932
parents
a588622a
c6fc5d35
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
347 additions
and
54 deletions
+347
-54
mysql-test/r/sp-destruct.result
mysql-test/r/sp-destruct.result
+77
-0
mysql-test/r/sp-error.result
mysql-test/r/sp-error.result
+1
-1
mysql-test/t/sp-destruct.test
mysql-test/t/sp-destruct.test
+124
-0
mysql-test/t/sp.test
mysql-test/t/sp.test
+2
-0
ndb/src/kernel/blocks/qmgr/QmgrMain.cpp
ndb/src/kernel/blocks/qmgr/QmgrMain.cpp
+10
-7
sql/share/errmsg.txt
sql/share/errmsg.txt
+2
-0
sql/sp.cc
sql/sp.cc
+81
-24
sql/sp.h
sql/sp.h
+5
-5
sql/sql_base.cc
sql/sql_base.cc
+39
-8
sql/sql_parse.cc
sql/sql_parse.cc
+0
-8
sql/sql_trigger.h
sql/sql_trigger.h
+1
-1
sql/sql_yacc.yy
sql/sql_yacc.yy
+5
-0
No files found.
mysql-test/r/sp-destruct.result
0 → 100644
View file @
56a59f98
use test;
drop procedure if exists bug14233;
drop function if exists bug14233;
drop table if exists t1;
drop view if exists v1;
create procedure bug14233()
set @x = 42;
create function bug14233_f() returns int
return 42;
create table t1 (id int);
create trigger t1_ai after insert on t1 for each row call bug14233();
alter table mysql.proc drop type;
call bug14233();
ERROR HY000: Failed to load routine test.bug14233. The table mysql.proc is missing, corrupt, or contains bad data (internal code -5)
create view v1 as select bug14233_f();
ERROR HY000: Failed to load routine test.bug14233_f. The table mysql.proc is missing, corrupt, or contains bad data (internal code -5)
insert into t1 values (0);
ERROR HY000: Failed to load routine test.bug14233. The table mysql.proc is missing, corrupt, or contains bad data (internal code -5)
flush table mysql.proc;
call bug14233();
ERROR HY000: Incorrect information in file: './mysql/proc.frm'
create view v1 as select bug14233_f();
ERROR HY000: Incorrect information in file: './mysql/proc.frm'
insert into t1 values (0);
ERROR HY000: Incorrect information in file: './mysql/proc.frm'
flush table mysql.proc;
call bug14233();
ERROR 42S02: Table 'mysql.proc' doesn't exist
create view v1 as select bug14233_f();
ERROR 42S02: Table 'mysql.proc' doesn't exist
insert into t1 values (0);
ERROR 42S02: Table 'mysql.proc' doesn't exist
flush table mysql.proc;
flush privileges;
delete from mysql.proc where name like 'bug14233%';
insert into mysql.proc
(
db, name, type, specific_name, language, sql_data_access, is_deterministic,
security_type, param_list, returns, body, definer, created, modified,
sql_mode, comment
)
values
(
'test', 'bug14233_1', 'FUNCTION', 'bug14233_1', 'SQL', 'READS_SQL_DATA', 'NO',
'DEFINER', '', 'int(10)',
'select count(*) from mysql.user',
'root@localhost', NOW() , '0000-00-00 00:00:00', '', ''
),
(
'test', 'bug14233_2', 'FUNCTION', 'bug14233_2', 'SQL', 'READS_SQL_DATA', 'NO',
'DEFINER', '', 'int(10)',
'begin declare x int; select count(*) into x from mysql.user; end',
'root@localhost', NOW() , '0000-00-00 00:00:00', '', ''
),
(
'test', 'bug14233_3', 'PROCEDURE', 'bug14233_3', 'SQL', 'READS_SQL_DATA','NO',
'DEFINER', '', '',
'alksj wpsj sa ^#!@ ',
'root@localhost', NOW() , '0000-00-00 00:00:00', '', ''
);
select bug14233_1();
ERROR HY000: Failed to load routine test.bug14233_1. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
create view v1 as select bug14233_1();
ERROR HY000: Failed to load routine test.bug14233_1. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
select bug14233_2();
ERROR HY000: Failed to load routine test.bug14233_2. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
create view v1 as select bug14233_2();
ERROR HY000: Failed to load routine test.bug14233_2. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
call bug14233_3();
ERROR HY000: Failed to load routine test.bug14233_3. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
drop trigger t1_ai;
create trigger t1_ai after insert on t1 for each row call bug14233_3();
insert into t1 values (0);
ERROR HY000: Failed to load routine test.bug14233_3. The table mysql.proc is missing, corrupt, or contains bad data (internal code -6)
delete from mysql.proc where name like 'bug14233%';
drop trigger t1_ai;
drop table t1;
mysql-test/r/sp-error.result
View file @
56a59f98
...
@@ -124,7 +124,7 @@ begin
...
@@ -124,7 +124,7 @@ begin
declare x int;
declare x int;
set x = val+3;
set x = val+3;
end|
end|
ERROR 42000: No RETURN found in FUNCTION f
ERROR 42000: No RETURN found in FUNCTION
test.
f
create function f(val int) returns int
create function f(val int) returns int
begin
begin
declare x int;
declare x int;
...
...
mysql-test/t/sp-destruct.test
0 → 100644
View file @
56a59f98
#
# Destructive stored procedure tests
#
# We do horrible things to the mysql.proc table here, so any unexpected
# failures here might leave it in an undetermined state.
#
# In the case of trouble you might want to skip this.
#
# We're using --system things that probably doesn't work on Windows.
--
source
include
/
not_windows
.
inc
# Backup proc table
--
system
rm
-
rf
var
/
master
-
data
/
mysql
/
backup
--
system
mkdir
var
/
master
-
data
/
mysql
/
backup
--
system
cp
var
/
master
-
data
/
mysql
/
proc
.*
var
/
master
-
data
/
mysql
/
backup
/
use
test
;
--
disable_warnings
drop
procedure
if
exists
bug14233
;
drop
function
if
exists
bug14233
;
drop
table
if
exists
t1
;
drop
view
if
exists
v1
;
--
enable_warnings
create
procedure
bug14233
()
set
@
x
=
42
;
create
function
bug14233_f
()
returns
int
return
42
;
create
table
t1
(
id
int
);
create
trigger
t1_ai
after
insert
on
t1
for
each
row
call
bug14233
();
# Unsupported tampering with the mysql.proc definition
alter
table
mysql
.
proc
drop
type
;
--
error
ER_SP_PROC_TABLE_CORRUPT
call
bug14233
();
--
error
ER_SP_PROC_TABLE_CORRUPT
create
view
v1
as
select
bug14233_f
();
--
error
ER_SP_PROC_TABLE_CORRUPT
insert
into
t1
values
(
0
);
flush
table
mysql
.
proc
;
# Thrashing the .frm file
--
system
echo
'saljdlfa'
>
var
/
master
-
data
/
mysql
/
proc
.
frm
--
error
ER_NOT_FORM_FILE
call
bug14233
();
--
error
ER_NOT_FORM_FILE
create
view
v1
as
select
bug14233_f
();
--
error
ER_NOT_FORM_FILE
insert
into
t1
values
(
0
);
flush
table
mysql
.
proc
;
# Drop the mysql.proc table
--
system
rm
var
/
master
-
data
/
mysql
/
proc
.*
--
error
ER_NO_SUCH_TABLE
call
bug14233
();
--
error
ER_NO_SUCH_TABLE
create
view
v1
as
select
bug14233_f
();
--
error
ER_NO_SUCH_TABLE
insert
into
t1
values
(
0
);
# Restore mysql.proc
--
system
mv
var
/
master
-
data
/
mysql
/
backup
/*
var
/
master
-
data
/
mysql
/
--
system
rmdir
var
/
master
-
data
/
mysql
/
backup
flush
table
mysql
.
proc
;
flush
privileges
;
delete
from
mysql
.
proc
where
name
like
'bug14233%'
;
# Unsupported editing of mysql.proc, circumventing checks in "create ..."
insert
into
mysql
.
proc
(
db
,
name
,
type
,
specific_name
,
language
,
sql_data_access
,
is_deterministic
,
security_type
,
param_list
,
returns
,
body
,
definer
,
created
,
modified
,
sql_mode
,
comment
)
values
(
'test'
,
'bug14233_1'
,
'FUNCTION'
,
'bug14233_1'
,
'SQL'
,
'READS_SQL_DATA'
,
'NO'
,
'DEFINER'
,
''
,
'int(10)'
,
'select count(*) from mysql.user'
,
'root@localhost'
,
NOW
()
,
'0000-00-00 00:00:00'
,
''
,
''
),
(
'test'
,
'bug14233_2'
,
'FUNCTION'
,
'bug14233_2'
,
'SQL'
,
'READS_SQL_DATA'
,
'NO'
,
'DEFINER'
,
''
,
'int(10)'
,
'begin declare x int; select count(*) into x from mysql.user; end'
,
'root@localhost'
,
NOW
()
,
'0000-00-00 00:00:00'
,
''
,
''
),
(
'test'
,
'bug14233_3'
,
'PROCEDURE'
,
'bug14233_3'
,
'SQL'
,
'READS_SQL_DATA'
,
'NO'
,
'DEFINER'
,
''
,
''
,
'alksj wpsj sa ^#!@ '
,
'root@localhost'
,
NOW
()
,
'0000-00-00 00:00:00'
,
''
,
''
);
--
error
ER_SP_PROC_TABLE_CORRUPT
select
bug14233_1
();
--
error
ER_SP_PROC_TABLE_CORRUPT
create
view
v1
as
select
bug14233_1
();
--
error
ER_SP_PROC_TABLE_CORRUPT
select
bug14233_2
();
--
error
ER_SP_PROC_TABLE_CORRUPT
create
view
v1
as
select
bug14233_2
();
--
error
ER_SP_PROC_TABLE_CORRUPT
call
bug14233_3
();
drop
trigger
t1_ai
;
create
trigger
t1_ai
after
insert
on
t1
for
each
row
call
bug14233_3
();
--
error
ER_SP_PROC_TABLE_CORRUPT
insert
into
t1
values
(
0
);
# Clean-up
delete
from
mysql
.
proc
where
name
like
'bug14233%'
;
drop
trigger
t1_ai
;
drop
table
t1
;
mysql-test/t/sp.test
View file @
56a59f98
...
@@ -13,6 +13,8 @@
...
@@ -13,6 +13,8 @@
# Tests that require multiple connections, except security/privilege tests,
# Tests that require multiple connections, except security/privilege tests,
# go to sp-thread.
# go to sp-thread.
# Tests that uses 'goto' to into sp-goto.test (currently disabled)
# Tests that uses 'goto' to into sp-goto.test (currently disabled)
# Tests that destroys system tables (e.g. mysql.proc) for error testing
# go to sp-destruct.
use
test
;
use
test
;
...
...
ndb/src/kernel/blocks/qmgr/QmgrMain.cpp
View file @
56a59f98
...
@@ -2030,29 +2030,32 @@ void Qmgr::execAPI_REGREQ(Signal* signal)
...
@@ -2030,29 +2030,32 @@ void Qmgr::execAPI_REGREQ(Signal* signal)
}
//Qmgr::execAPI_REGREQ()
}
//Qmgr::execAPI_REGREQ()
void
void
Qmgr
::
execAPI_VERSION_REQ
(
Signal
*
signal
)
{
Qmgr
::
execAPI_VERSION_REQ
(
Signal
*
signal
)
{
jamEntry
();
jamEntry
();
ApiVersionReq
*
const
req
=
(
ApiVersionReq
*
)
signal
->
getDataPtr
();
ApiVersionReq
*
const
req
=
(
ApiVersionReq
*
)
signal
->
getDataPtr
();
Uint32
senderRef
=
req
->
senderRef
;
Uint32
senderRef
=
req
->
senderRef
;
Uint32
nodeId
=
req
->
nodeId
;
Uint32
nodeId
=
req
->
nodeId
;
ApiVersionConf
*
conf
=
(
ApiVersionConf
*
)
req
;
ApiVersionConf
*
conf
=
(
ApiVersionConf
*
)
req
;
if
(
getNodeInfo
(
nodeId
).
m_connected
)
if
(
getNodeInfo
(
nodeId
).
m_connected
)
{
conf
->
version
=
getNodeInfo
(
nodeId
).
m_version
;
conf
->
version
=
getNodeInfo
(
nodeId
).
m_version
;
struct
in_addr
in
=
globalTransporterRegistry
.
get_connect_address
(
nodeId
);
conf
->
inet_addr
=
in
.
s_addr
;
}
else
else
{
conf
->
version
=
0
;
conf
->
version
=
0
;
conf
->
inet_addr
=
0
;
}
conf
->
nodeId
=
nodeId
;
conf
->
nodeId
=
nodeId
;
struct
in_addr
in
=
globalTransporterRegistry
.
get_connect_address
(
nodeId
);
conf
->
inet_addr
=
in
.
s_addr
;
sendSignal
(
senderRef
,
sendSignal
(
senderRef
,
GSN_API_VERSION_CONF
,
GSN_API_VERSION_CONF
,
signal
,
signal
,
ApiVersionConf
::
SignalLength
,
JBB
);
ApiVersionConf
::
SignalLength
,
JBB
);
}
}
...
...
sql/share/errmsg.txt
View file @
56a59f98
...
@@ -5600,3 +5600,5 @@ ER_OLD_FILE_FORMAT
...
@@ -5600,3 +5600,5 @@ ER_OLD_FILE_FORMAT
eng "'%-.64s' has an old format, you should re-create the '%s' object(s)"
eng "'%-.64s' has an old format, you should re-create the '%s' object(s)"
ER_SP_RECURSION_LIMIT
ER_SP_RECURSION_LIMIT
eng "Recursive limit %d (as set by the max_sp_recursion_depth variable) was exceeded for routine %.64s"
eng "Recursive limit %d (as set by the max_sp_recursion_depth variable) was exceeded for routine %.64s"
ER_SP_PROC_TABLE_CORRUPT
eng "Failed to load routine %s. The table mysql.proc is missing, corrupt, or contains bad data (internal code %d)"
sql/sp.cc
View file @
56a59f98
...
@@ -1446,21 +1446,23 @@ static void sp_update_stmt_used_routines(THD *thd, LEX *lex, SQL_LIST *src)
...
@@ -1446,21 +1446,23 @@ static void sp_update_stmt_used_routines(THD *thd, LEX *lex, SQL_LIST *src)
first_no_prelock - If true, don't add tables or cache routines used by
first_no_prelock - If true, don't add tables or cache routines used by
the body of the first routine (i.e. *start)
the body of the first routine (i.e. *start)
will be executed in non-prelocked mode.
will be executed in non-prelocked mode.
tabs_changed - Set to TRUE some tables were added, FALSE otherwise
NOTE
NOTE
If some function is missing this won't be reported here.
If some function is missing this won't be reported here.
Instead this fact will be discovered during query execution.
Instead this fact will be discovered during query execution.
RETURN VALUE
RETURN VALUE
TRUE - some tables were added
0 - success
FALSE - no tables were added.
non-0 - failure
*/
*/
static
bool
static
int
sp_cache_routines_and_add_tables_aux
(
THD
*
thd
,
LEX
*
lex
,
sp_cache_routines_and_add_tables_aux
(
THD
*
thd
,
LEX
*
lex
,
Sroutine_hash_entry
*
start
,
Sroutine_hash_entry
*
start
,
bool
first_no_prelock
)
bool
first_no_prelock
,
bool
*
tabs_changed
)
{
{
bool
result
=
FALSE
;
int
ret
=
0
;
bool
tabschnd
=
0
;
/* Set if tables changed */
bool
first
=
TRUE
;
bool
first
=
TRUE
;
DBUG_ENTER
(
"sp_cache_routines_and_add_tables_aux"
);
DBUG_ENTER
(
"sp_cache_routines_and_add_tables_aux"
);
...
@@ -1481,12 +1483,50 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
...
@@ -1481,12 +1483,50 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
name
.
m_name
.
str
+=
1
;
name
.
m_name
.
str
+=
1
;
name
.
m_name
.
length
=
name
.
m_qname
.
length
-
name
.
m_db
.
length
-
1
;
name
.
m_name
.
length
=
name
.
m_qname
.
length
-
name
.
m_db
.
length
-
1
;
if
(
db_find_routine
(
thd
,
type
,
&
name
,
&
sp
)
==
SP_OK
)
switch
((
ret
=
db_find_routine
(
thd
,
type
,
&
name
,
&
sp
))
)
{
{
if
(
type
==
TYPE_ENUM_FUNCTION
)
case
SP_OK
:
sp_cache_insert
(
&
thd
->
sp_func_cache
,
sp
);
{
else
if
(
type
==
TYPE_ENUM_FUNCTION
)
sp_cache_insert
(
&
thd
->
sp_proc_cache
,
sp
);
sp_cache_insert
(
&
thd
->
sp_func_cache
,
sp
);
else
sp_cache_insert
(
&
thd
->
sp_proc_cache
,
sp
);
}
break
;
case
SP_KEY_NOT_FOUND
:
ret
=
SP_OK
;
break
;
case
SP_OPEN_TABLE_FAILED
:
/*
Force it to attempt opening it again on subsequent calls;
otherwise we will get one error message the first time, and
then ER_SP_PROC_TABLE_CORRUPT (below) on subsequent tries.
*/
mysql_proc_table_exists
=
1
;
/* Fall through */
default:
/*
Any error when loading an existing routine is either some problem
with the mysql.proc table, or a parse error because the contents
has been tampered with (in which case we clear that error).
*/
if
(
ret
==
SP_PARSE_ERROR
)
thd
->
clear_error
();
/*
If we cleared the parse error, or when db_find_routine() flagged
an error with it's return value without calling my_error(), we
set the generic "mysql.proc table corrupt" error here.
*/
if
(
!
thd
->
net
.
report_error
)
{
char
n
[
NAME_LEN
*
2
+
2
];
/* m_qname.str is not always \0 terminated */
memcpy
(
n
,
name
.
m_qname
.
str
,
name
.
m_qname
.
length
);
n
[
name
.
m_qname
.
length
]
=
'\0'
;
my_error
(
ER_SP_PROC_TABLE_CORRUPT
,
MYF
(
0
),
n
,
ret
);
}
break
;
}
}
}
}
if
(
sp
)
if
(
sp
)
...
@@ -1494,12 +1534,15 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
...
@@ -1494,12 +1534,15 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
if
(
!
(
first
&&
first_no_prelock
))
if
(
!
(
first
&&
first_no_prelock
))
{
{
sp_update_stmt_used_routines
(
thd
,
lex
,
&
sp
->
m_sroutines
);
sp_update_stmt_used_routines
(
thd
,
lex
,
&
sp
->
m_sroutines
);
result
|=
sp
->
add_used_tables_to_table_list
(
thd
,
&
lex
->
query_tables_last
);
tabschnd
|=
sp
->
add_used_tables_to_table_list
(
thd
,
&
lex
->
query_tables_last
);
}
}
}
}
first
=
FALSE
;
first
=
FALSE
;
}
}
DBUG_RETURN
(
result
);
if
(
tabs_changed
)
/* it can be NULL */
*
tabs_changed
=
tabschnd
;
DBUG_RETURN
(
ret
);
}
}
...
@@ -1514,18 +1557,20 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
...
@@ -1514,18 +1557,20 @@ sp_cache_routines_and_add_tables_aux(THD *thd, LEX *lex,
lex - LEX representing statement
lex - LEX representing statement
first_no_prelock - If true, don't add tables or cache routines used by
first_no_prelock - If true, don't add tables or cache routines used by
the body of the first routine (i.e. *start)
the body of the first routine (i.e. *start)
tabs_changed - Set to TRUE some tables were added, FALSE otherwise
RETURN VALUE
RETURN VALUE
TRUE - some tables were added
0 - success
FALSE - no tables were added.
non-0 - failure
*/
*/
bool
int
sp_cache_routines_and_add_tables
(
THD
*
thd
,
LEX
*
lex
,
bool
first_no_prelock
)
sp_cache_routines_and_add_tables
(
THD
*
thd
,
LEX
*
lex
,
bool
first_no_prelock
,
bool
*
tabs_changed
)
{
{
return
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
return
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
(
Sroutine_hash_entry
*
)
lex
->
sroutines_list
.
first
,
(
Sroutine_hash_entry
*
)
lex
->
sroutines_list
.
first
,
first_no_prelock
);
first_no_prelock
,
tabs_changed
);
}
}
...
@@ -1539,16 +1584,21 @@ sp_cache_routines_and_add_tables(THD *thd, LEX *lex, bool first_no_prelock)
...
@@ -1539,16 +1584,21 @@ sp_cache_routines_and_add_tables(THD *thd, LEX *lex, bool first_no_prelock)
thd - thread context
thd - thread context
lex - LEX representing statement
lex - LEX representing statement
aux_lex - LEX representing view
aux_lex - LEX representing view
RETURN VALUE
0 - success
non-0 - failure
*/
*/
void
int
sp_cache_routines_and_add_tables_for_view
(
THD
*
thd
,
LEX
*
lex
,
LEX
*
aux_lex
)
sp_cache_routines_and_add_tables_for_view
(
THD
*
thd
,
LEX
*
lex
,
LEX
*
aux_lex
)
{
{
Sroutine_hash_entry
**
last_cached_routine_ptr
=
Sroutine_hash_entry
**
last_cached_routine_ptr
=
(
Sroutine_hash_entry
**
)
lex
->
sroutines_list
.
next
;
(
Sroutine_hash_entry
**
)
lex
->
sroutines_list
.
next
;
sp_update_stmt_used_routines
(
thd
,
lex
,
&
aux_lex
->
sroutines_list
);
sp_update_stmt_used_routines
(
thd
,
lex
,
&
aux_lex
->
sroutines_list
);
(
void
)
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
return
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
*
last_cached_routine_ptr
,
FALSE
);
*
last_cached_routine_ptr
,
FALSE
,
NULL
);
}
}
...
@@ -1562,12 +1612,18 @@ sp_cache_routines_and_add_tables_for_view(THD *thd, LEX *lex, LEX *aux_lex)
...
@@ -1562,12 +1612,18 @@ sp_cache_routines_and_add_tables_for_view(THD *thd, LEX *lex, LEX *aux_lex)
thd - thread context
thd - thread context
lex - LEX respresenting statement
lex - LEX respresenting statement
triggers - triggers of the table
triggers - triggers of the table
RETURN VALUE
0 - success
non-0 - failure
*/
*/
void
int
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
Table_triggers_list
*
triggers
)
Table_triggers_list
*
triggers
)
{
{
int
ret
=
0
;
if
(
add_used_routine
(
lex
,
thd
->
stmt_arena
,
&
triggers
->
sroutines_key
))
if
(
add_used_routine
(
lex
,
thd
->
stmt_arena
,
&
triggers
->
sroutines_key
))
{
{
Sroutine_hash_entry
**
last_cached_routine_ptr
=
Sroutine_hash_entry
**
last_cached_routine_ptr
=
...
@@ -1585,10 +1641,11 @@ sp_cache_routines_and_add_tables_for_triggers(THD *thd, LEX *lex,
...
@@ -1585,10 +1641,11 @@ sp_cache_routines_and_add_tables_for_triggers(THD *thd, LEX *lex,
}
}
}
}
}
}
(
void
)
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
ret
=
sp_cache_routines_and_add_tables_aux
(
thd
,
lex
,
*
last_cached_routine_ptr
,
*
last_cached_routine_ptr
,
FALSE
);
FALSE
,
NULL
);
}
}
return
ret
;
}
}
...
...
sql/sp.h
View file @
56a59f98
...
@@ -84,11 +84,11 @@ void sp_add_used_routine(LEX *lex, Query_arena *arena,
...
@@ -84,11 +84,11 @@ void sp_add_used_routine(LEX *lex, Query_arena *arena,
sp_name
*
rt
,
char
rt_type
);
sp_name
*
rt
,
char
rt_type
);
void
sp_remove_not_own_routines
(
LEX
*
lex
);
void
sp_remove_not_own_routines
(
LEX
*
lex
);
void
sp_update_sp_used_routines
(
HASH
*
dst
,
HASH
*
src
);
void
sp_update_sp_used_routines
(
HASH
*
dst
,
HASH
*
src
);
bool
sp_cache_routines_and_add_tables
(
THD
*
thd
,
LEX
*
lex
,
int
sp_cache_routines_and_add_tables
(
THD
*
thd
,
LEX
*
lex
,
bool
first_no_prelock
);
bool
first_no_prelock
,
bool
*
tabs_changed
);
void
sp_cache_routines_and_add_tables_for_view
(
THD
*
thd
,
LEX
*
lex
,
int
sp_cache_routines_and_add_tables_for_view
(
THD
*
thd
,
LEX
*
lex
,
LEX
*
aux_lex
);
LEX
*
aux_lex
);
void
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
int
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
Table_triggers_list
*
triggers
);
Table_triggers_list
*
triggers
);
extern
"C"
byte
*
sp_sroutine_key
(
const
byte
*
ptr
,
uint
*
plen
,
my_bool
first
);
extern
"C"
byte
*
sp_sroutine_key
(
const
byte
*
ptr
,
uint
*
plen
,
my_bool
first
);
...
...
sql/sql_base.cc
View file @
56a59f98
...
@@ -1984,15 +1984,25 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
...
@@ -1984,15 +1984,25 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
if
(
!
thd
->
prelocked_mode
&&
!
thd
->
lex
->
requires_prelocking
()
&&
if
(
!
thd
->
prelocked_mode
&&
!
thd
->
lex
->
requires_prelocking
()
&&
thd
->
lex
->
sroutines_list
.
elements
)
thd
->
lex
->
sroutines_list
.
elements
)
{
{
bool
first_no_prelocking
,
need_prelocking
;
bool
first_no_prelocking
,
need_prelocking
,
tabs_changed
;
TABLE_LIST
**
save_query_tables_last
=
thd
->
lex
->
query_tables_last
;
TABLE_LIST
**
save_query_tables_last
=
thd
->
lex
->
query_tables_last
;
DBUG_ASSERT
(
thd
->
lex
->
query_tables
==
*
start
);
DBUG_ASSERT
(
thd
->
lex
->
query_tables
==
*
start
);
sp_get_prelocking_info
(
thd
,
&
need_prelocking
,
&
first_no_prelocking
);
sp_get_prelocking_info
(
thd
,
&
need_prelocking
,
&
first_no_prelocking
);
if
((
sp_cache_routines_and_add_tables
(
thd
,
thd
->
lex
,
if
(
sp_cache_routines_and_add_tables
(
thd
,
thd
->
lex
,
first_no_prelocking
)
||
first_no_prelocking
,
*
start
)
&&
need_prelocking
)
&
tabs_changed
))
{
/*
Serious error during reading stored routines from mysql.proc table.
Something's wrong with the table or its contents, and an error has
been emitted; we must abort.
*/
result
=
-
1
;
goto
err
;
}
else
if
((
tabs_changed
||
*
start
)
&&
need_prelocking
)
{
{
query_tables_last_own
=
save_query_tables_last
;
query_tables_last_own
=
save_query_tables_last
;
*
start
=
thd
->
lex
->
query_tables
;
*
start
=
thd
->
lex
->
query_tables
;
...
@@ -2116,9 +2126,18 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
...
@@ -2116,9 +2126,18 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
tables
->
lock_type
>=
TL_WRITE_ALLOW_WRITE
)
tables
->
lock_type
>=
TL_WRITE_ALLOW_WRITE
)
{
{
if
(
!
query_tables_last_own
)
if
(
!
query_tables_last_own
)
query_tables_last_own
=
thd
->
lex
->
query_tables_last
;
query_tables_last_own
=
thd
->
lex
->
query_tables_last
;
sp_cache_routines_and_add_tables_for_triggers
(
thd
,
thd
->
lex
,
if
(
sp_cache_routines_and_add_tables_for_triggers
(
thd
,
thd
->
lex
,
tables
->
table
->
triggers
);
tables
->
table
->
triggers
))
{
/*
Serious error during reading stored routines from mysql.proc table.
Something's wrong with the table or its contents, and an error has
been emitted; we must abort.
*/
result
=
-
1
;
goto
err
;
}
}
}
free_root
(
&
new_frm_mem
,
MYF
(
MY_KEEP_PREALLOC
));
free_root
(
&
new_frm_mem
,
MYF
(
MY_KEEP_PREALLOC
));
}
}
...
@@ -2139,9 +2158,21 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
...
@@ -2139,9 +2158,21 @@ int open_tables(THD *thd, TABLE_LIST **start, uint *counter, uint flags)
/* We have at least one table in TL here. */
/* We have at least one table in TL here. */
if
(
!
query_tables_last_own
)
if
(
!
query_tables_last_own
)
query_tables_last_own
=
thd
->
lex
->
query_tables_last
;
query_tables_last_own
=
thd
->
lex
->
query_tables_last
;
sp_cache_routines_and_add_tables_for_view
(
thd
,
thd
->
lex
,
tables
->
view
);
if
(
sp_cache_routines_and_add_tables_for_view
(
thd
,
thd
->
lex
,
tables
->
view
))
{
/*
Serious error during reading stored routines from mysql.proc table.
Something's wrong with the table or its contents, and an error has
been emitted; we must abort.
*/
result
=
-
1
;
goto
err
;
}
}
}
}
}
err:
thd
->
proc_info
=
0
;
thd
->
proc_info
=
0
;
free_root
(
&
new_frm_mem
,
MYF
(
0
));
// Free pre-alloced block
free_root
(
&
new_frm_mem
,
MYF
(
0
));
// Free pre-alloced block
...
...
sql/sql_parse.cc
View file @
56a59f98
...
@@ -4133,14 +4133,6 @@ mysql_execute_command(THD *thd)
...
@@ -4133,14 +4133,6 @@ mysql_execute_command(THD *thd)
}
}
}
}
#endif
#endif
if
(
lex
->
sphead
->
m_type
==
TYPE_ENUM_FUNCTION
&&
!
(
lex
->
sphead
->
m_flags
&
sp_head
::
HAS_RETURN
))
{
my_error
(
ER_SP_NORETURN
,
MYF
(
0
),
name
);
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
goto
error
;
}
/*
/*
We need to copy name and db in order to use them for
We need to copy name and db in order to use them for
...
...
sql/sql_trigger.h
View file @
56a59f98
...
@@ -117,7 +117,7 @@ class Table_triggers_list: public Sql_alloc
...
@@ -117,7 +117,7 @@ class Table_triggers_list: public Sql_alloc
void
set_table
(
TABLE
*
new_table
);
void
set_table
(
TABLE
*
new_table
);
friend
class
Item_trigger_field
;
friend
class
Item_trigger_field
;
friend
void
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
friend
int
sp_cache_routines_and_add_tables_for_triggers
(
THD
*
thd
,
LEX
*
lex
,
Table_triggers_list
*
triggers
);
Table_triggers_list
*
triggers
);
private:
private:
...
...
sql/sql_yacc.yy
View file @
56a59f98
...
@@ -1407,6 +1407,11 @@ create_function_tail:
...
@@ -1407,6 +1407,11 @@ create_function_tail:
YYABORT;
YYABORT;
lex->sql_command= SQLCOM_CREATE_SPFUNCTION;
lex->sql_command= SQLCOM_CREATE_SPFUNCTION;
sp->init_strings(YYTHD, lex, lex->spname);
sp->init_strings(YYTHD, lex, lex->spname);
if (!(sp->m_flags & sp_head::HAS_RETURN))
{
my_error(ER_SP_NORETURN, MYF(0), sp->m_qname.str);
YYABORT;
}
/* Restore flag if it was cleared above */
/* Restore flag if it was cleared above */
if (sp->m_old_cmq)
if (sp->m_old_cmq)
YYTHD->client_capabilities |= CLIENT_MULTI_QUERIES;
YYTHD->client_capabilities |= CLIENT_MULTI_QUERIES;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment