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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
e6d72f1c
Commit
e6d72f1c
authored
Apr 08, 2005
by
pem@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/usr/local/bk/mysql-5.0
into mysql.com:/home/pem/work/mysql-5.0
parents
20a82a1a
ce2e40ac
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
189 additions
and
6 deletions
+189
-6
mysql-test/r/sp-error.result
mysql-test/r/sp-error.result
+13
-0
mysql-test/r/sp.result
mysql-test/r/sp.result
+65
-0
mysql-test/t/sp-error.test
mysql-test/t/sp-error.test
+22
-0
mysql-test/t/sp.test
mysql-test/t/sp.test
+83
-0
sql/sp_rcontext.cc
sql/sp_rcontext.cc
+6
-6
No files found.
mysql-test/r/sp-error.result
View file @
e6d72f1c
...
...
@@ -513,4 +513,17 @@ call bug9566()|
ERROR HY000: Table 'proc' was not locked with LOCK TABLES
unlock tables|
drop procedure bug9566|
drop procedure if exists bug7299|
create procedure bug7299()
begin
declare v int;
declare c cursor for select val from t1;
declare exit handler for sqlexception select 'Error!';
open c;
fetch c into v;
end|
delete from t1|
call bug7299()|
ERROR 02000: No data to FETCH
drop procedure bug7299|
drop table t1|
mysql-test/r/sp.result
View file @
e6d72f1c
...
...
@@ -2779,4 +2779,69 @@ a
3.2000
drop procedure bug8937|
delete from t1|
drop procedure if exists bug6900|
drop procedure if exists bug9074|
drop procedure if exists bug6900_9074|
drop table if exists t3|
create table t3 (w char unique, x char)|
insert into t3 values ('a', 'b')|
create procedure bug6900()
begin
declare exit handler for sqlexception select '1';
begin
declare exit handler for sqlexception select '2';
insert into t3 values ('x', 'y', 'z');
end;
end|
create procedure bug9074()
begin
declare x1, x2, x3, x4, x5, x6 int default 0;
begin
declare continue handler for sqlstate '23000' set x5 = 1;
insert into t3 values ('a', 'b');
set x6 = 1;
end;
begin1_label:
begin
declare continue handler for sqlstate '23000' set x1 = 1;
insert into t3 values ('a', 'b');
set x2 = 1;
begin2_label:
begin
declare exit handler for sqlstate '23000' set x3 = 1;
set x4= 1;
insert into t3 values ('a','b');
set x4= 0;
end begin2_label;
end begin1_label;
select x1, x2, x3, x4, x5, x6;
end|
create procedure bug6900_9074(z int)
begin
declare exit handler for sqlstate '23000' select '23000';
begin
declare exit handler for sqlexception select 'sqlexception';
if z = 1 then
insert into t3 values ('a', 'b');
else
insert into t3 values ('x', 'y', 'z');
end if;
end;
end|
call bug6900()|
2
2
call bug9074()|
x1 x2 x3 x4 x5 x6
1 1 1 1 1 1
call bug6900_9074(0)|
sqlexception
sqlexception
call bug6900_9074(1)|
23000
23000
drop procedure bug6900|
drop procedure bug9074|
drop procedure bug6900_9074|
drop table t3|
drop table t1,t2;
mysql-test/t/sp-error.test
View file @
e6d72f1c
...
...
@@ -720,6 +720,28 @@ unlock tables|
drop
procedure
bug9566
|
#
# BUG#7299: Stored procedures: exception handler catches not-found conditions
#
--
disable_warnings
drop
procedure
if
exists
bug7299
|
--
enable_warnings
create
procedure
bug7299
()
begin
declare
v
int
;
declare
c
cursor
for
select
val
from
t1
;
declare
exit
handler
for
sqlexception
select
'Error!'
;
open
c
;
fetch
c
into
v
;
end
|
delete
from
t1
|
--
error
ER_SP_FETCH_NO_DATA
call
bug7299
()
|
drop
procedure
bug7299
|
#
# BUG#NNNN: New bug synopsis
#
...
...
mysql-test/t/sp.test
View file @
e6d72f1c
...
...
@@ -3398,6 +3398,89 @@ drop procedure bug8937|
delete
from
t1
|
#
# BUG#6900: Stored procedure inner handler ignored
# BUG#9074: STORED PROC: The scope of every handler declared is not
# properly applied
#
--
disable_warnings
drop
procedure
if
exists
bug6900
|
drop
procedure
if
exists
bug9074
|
drop
procedure
if
exists
bug6900_9074
|
drop
table
if
exists
t3
|
--
enable_warnings
create
table
t3
(
w
char
unique
,
x
char
)
|
insert
into
t3
values
(
'a'
,
'b'
)
|
create
procedure
bug6900
()
begin
declare
exit
handler
for
sqlexception
select
'1'
;
begin
declare
exit
handler
for
sqlexception
select
'2'
;
insert
into
t3
values
(
'x'
,
'y'
,
'z'
);
end
;
end
|
create
procedure
bug9074
()
begin
declare
x1
,
x2
,
x3
,
x4
,
x5
,
x6
int
default
0
;
begin
declare
continue
handler
for
sqlstate
'23000'
set
x5
=
1
;
insert
into
t3
values
(
'a'
,
'b'
);
set
x6
=
1
;
end
;
begin1_label
:
begin
declare
continue
handler
for
sqlstate
'23000'
set
x1
=
1
;
insert
into
t3
values
(
'a'
,
'b'
);
set
x2
=
1
;
begin2_label
:
begin
declare
exit
handler
for
sqlstate
'23000'
set
x3
=
1
;
set
x4
=
1
;
insert
into
t3
values
(
'a'
,
'b'
);
set
x4
=
0
;
end
begin2_label
;
end
begin1_label
;
select
x1
,
x2
,
x3
,
x4
,
x5
,
x6
;
end
|
create
procedure
bug6900_9074
(
z
int
)
begin
declare
exit
handler
for
sqlstate
'23000'
select
'23000'
;
begin
declare
exit
handler
for
sqlexception
select
'sqlexception'
;
if
z
=
1
then
insert
into
t3
values
(
'a'
,
'b'
);
else
insert
into
t3
values
(
'x'
,
'y'
,
'z'
);
end
if
;
end
;
end
|
call
bug6900
()
|
call
bug9074
()
|
call
bug6900_9074
(
0
)
|
call
bug6900_9074
(
1
)
|
drop
procedure
bug6900
|
drop
procedure
bug9074
|
drop
procedure
bug6900_9074
|
drop
table
t3
|
#
# BUG#NNNN: New bug synopsis
#
...
...
sql/sp_rcontext.cc
View file @
e6d72f1c
...
...
@@ -80,24 +80,24 @@ sp_rcontext::find_handler(uint sql_errno,
break
;
case
sp_cond_type_t
:
:
state
:
if
(
strcmp
(
sqlstate
,
cond
->
sqlstate
)
==
0
&&
(
found
<
0
||
m_handler
[
found
].
cond
->
type
>
sp_cond_type_t
::
number
))
(
found
<
0
||
m_handler
[
found
].
cond
->
type
>
sp_cond_type_t
::
state
))
found
=
i
;
break
;
case
sp_cond_type_t
:
:
warning
:
if
((
sqlstate
[
0
]
==
'0'
&&
sqlstate
[
1
]
==
'1'
||
level
==
MYSQL_ERROR
::
WARN_LEVEL_WARN
)
&&
(
found
<
0
||
m_handler
[
found
].
cond
->
type
>
sp_cond_type_t
::
state
)
)
found
<
0
)
found
=
i
;
break
;
case
sp_cond_type_t
:
:
notfound
:
if
(
sqlstate
[
0
]
==
'0'
&&
sqlstate
[
1
]
==
'2'
&&
(
found
<
0
||
m_handler
[
found
].
cond
->
type
>
sp_cond_type_t
::
state
)
)
found
<
0
)
found
=
i
;
break
;
case
sp_cond_type_t
:
:
exception
:
if
((
sqlstate
[
0
]
!=
'0'
||
sqlstate
[
1
]
>
'2'
||
level
==
MYSQL_ERROR
::
WARN_LEVEL_ERROR
)
&&
(
found
<
0
||
m_handler
[
found
].
cond
->
type
>
sp_cond_type_t
::
state
)
)
if
((
sqlstate
[
0
]
!=
'0'
||
sqlstate
[
1
]
>
'2'
)
&&
level
==
MYSQL_ERROR
::
WARN_LEVEL_ERROR
&&
found
<
0
)
found
=
i
;
break
;
}
...
...
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