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
e00266de
Commit
e00266de
authored
Nov 25, 2004
by
unknown
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
3346feb8
ea75abc5
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
69 additions
and
25 deletions
+69
-25
mysql-test/r/sp-error.result
mysql-test/r/sp-error.result
+13
-0
mysql-test/t/sp-error.test
mysql-test/t/sp-error.test
+22
-0
sql/sql_lex.h
sql/sql_lex.h
+1
-2
sql/sql_parse.cc
sql/sql_parse.cc
+26
-2
sql/sql_yacc.yy
sql/sql_yacc.yy
+7
-21
No files found.
mysql-test/r/sp-error.result
View file @
e00266de
...
@@ -460,4 +460,17 @@ end|
...
@@ -460,4 +460,17 @@ end|
call bug3294()|
call bug3294()|
ERROR 42S02: Unknown table 't5'
ERROR 42S02: Unknown table 't5'
drop procedure bug3294|
drop procedure bug3294|
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 table t1|
drop table t1|
mysql-test/t/sp-error.test
View file @
e00266de
...
@@ -632,6 +632,28 @@ end|
...
@@ -632,6 +632,28 @@ end|
call
bug3294
()
|
call
bug3294
()
|
drop
procedure
bug3294
|
drop
procedure
bug3294
|
#
# BUG#6807: Stored procedure crash if CREATE PROCEDURE ... KILL QUERY
#
--
disable_warnings
drop
procedure
if
exists
bug6807
|
--
enable_warnings
create
procedure
bug6807
()
begin
declare
id
int
;
set
id
=
connection_id
();
kill
query
id
;
select
'Not reached'
;
end
|
--
error
1317
call
bug6807
()
|
--
error
1317
call
bug6807
()
|
drop
procedure
bug6807
|
drop
table
t1
|
drop
table
t1
|
...
...
sql/sql_lex.h
View file @
e00266de
...
@@ -650,7 +650,6 @@ typedef struct st_lex
...
@@ -650,7 +650,6 @@ typedef struct st_lex
char
*
help_arg
;
char
*
help_arg
;
char
*
backup_dir
;
/* For RESTORE/BACKUP */
char
*
backup_dir
;
/* For RESTORE/BACKUP */
char
*
to_log
;
/* For PURGE MASTER LOGS TO */
char
*
to_log
;
/* For PURGE MASTER LOGS TO */
time_t
purge_time
;
/* For PURGE MASTER LOGS BEFORE */
char
*
x509_subject
,
*
x509_issuer
,
*
ssl_cipher
;
char
*
x509_subject
,
*
x509_issuer
,
*
ssl_cipher
;
char
*
found_colon
;
/* For multi queries - next query */
char
*
found_colon
;
/* For multi queries - next query */
String
*
wild
;
String
*
wild
;
...
@@ -694,7 +693,7 @@ typedef struct st_lex
...
@@ -694,7 +693,7 @@ typedef struct st_lex
HA_CREATE_INFO
create_info
;
HA_CREATE_INFO
create_info
;
LEX_MASTER_INFO
mi
;
// used by CHANGE MASTER
LEX_MASTER_INFO
mi
;
// used by CHANGE MASTER
USER_RESOURCES
mqh
;
USER_RESOURCES
mqh
;
ulong
t
hread_id
,
t
ype
;
ulong
type
;
enum_sql_command
sql_command
,
orig_sql_command
;
enum_sql_command
sql_command
,
orig_sql_command
;
thr_lock_type
lock_option
,
multi_lock_option
;
thr_lock_type
lock_option
,
multi_lock_option
;
enum
SSL_type
ssl_type
;
/* defined in violite.h */
enum
SSL_type
ssl_type
;
/* defined in violite.h */
...
...
sql/sql_parse.cc
View file @
e00266de
...
@@ -2327,10 +2327,24 @@ mysql_execute_command(THD *thd)
...
@@ -2327,10 +2327,24 @@ mysql_execute_command(THD *thd)
}
}
case
SQLCOM_PURGE_BEFORE
:
case
SQLCOM_PURGE_BEFORE
:
{
{
Item
*
it
;
if
(
check_global_access
(
thd
,
SUPER_ACL
))
if
(
check_global_access
(
thd
,
SUPER_ACL
))
goto
error
;
goto
error
;
/* PURGE MASTER LOGS BEFORE 'data' */
/* PURGE MASTER LOGS BEFORE 'data' */
res
=
purge_master_logs_before_date
(
thd
,
lex
->
purge_time
);
it
=
(
Item
*
)
lex
->
value_list
.
head
();
if
(
it
->
check_cols
(
1
)
||
it
->
fix_fields
(
lex
->
thd
,
0
,
&
it
))
{
my_error
(
ER_WRONG_ARGUMENTS
,
MYF
(
0
),
"PURGE LOGS BEFORE"
);
goto
error
;
}
it
=
new
Item_func_unix_timestamp
(
it
);
/*
it is OK only emulate fix_fieds, because we need only
value of constant
*/
it
->
quick_fix_field
();
res
=
purge_master_logs_before_date
(
thd
,
(
ulong
)
it
->
val_int
());
break
;
break
;
}
}
#endif
#endif
...
@@ -3505,8 +3519,18 @@ mysql_execute_command(THD *thd)
...
@@ -3505,8 +3519,18 @@ mysql_execute_command(THD *thd)
break
;
break
;
}
}
case
SQLCOM_KILL
:
case
SQLCOM_KILL
:
kill_one_thread
(
thd
,
lex
->
thread_id
,
lex
->
type
&
ONLY_KILL_QUERY
);
{
Item
*
it
=
(
Item
*
)
lex
->
value_list
.
head
();
if
(
it
->
fix_fields
(
lex
->
thd
,
0
,
&
it
)
||
it
->
check_cols
(
1
))
{
my_message
(
ER_SET_CONSTANTS_ONLY
,
ER
(
ER_SET_CONSTANTS_ONLY
),
MYF
(
0
));
goto
error
;
}
kill_one_thread
(
thd
,
(
ulong
)
it
->
val_int
(),
lex
->
type
&
ONLY_KILL_QUERY
);
break
;
break
;
}
#ifndef NO_EMBEDDED_ACCESS_CHECKS
#ifndef NO_EMBEDDED_ACCESS_CHECKS
case
SQLCOM_SHOW_GRANTS
:
case
SQLCOM_SHOW_GRANTS
:
if
((
thd
->
priv_user
&&
if
((
thd
->
priv_user
&&
...
...
sql/sql_yacc.yy
View file @
e00266de
...
@@ -6280,19 +6280,10 @@ purge_option:
...
@@ -6280,19 +6280,10 @@ purge_option:
}
}
| BEFORE_SYM expr
| BEFORE_SYM expr
{
{
if ($2->check_cols(1) || $2->fix_fields(Lex->thd, 0, &$2))
LEX *lex= Lex;
{
lex->value_list.empty();
my_error(ER_WRONG_ARGUMENTS, MYF(0), "PURGE LOGS BEFORE");
lex->value_list.push_front($2);
YYABORT;
lex->sql_command= SQLCOM_PURGE_BEFORE;
}
Item *tmp= new Item_func_unix_timestamp($2);
/*
it is OK only emulate fix_fieds, because we need only
value of constant
*/
tmp->quick_fix_field();
Lex->sql_command = SQLCOM_PURGE_BEFORE;
Lex->purge_time= (ulong) tmp->val_int();
}
}
;
;
...
@@ -6302,14 +6293,9 @@ kill:
...
@@ -6302,14 +6293,9 @@ kill:
KILL_SYM kill_option expr
KILL_SYM kill_option expr
{
{
LEX *lex=Lex;
LEX *lex=Lex;
if ($3->fix_fields(lex->thd, 0, &$3) || $3->check_cols(1))
lex->value_list.empty();
{
lex->value_list.push_front($3);
my_message(ER_SET_CONSTANTS_ONLY, ER(ER_SET_CONSTANTS_ONLY),
lex->sql_command= SQLCOM_KILL;
MYF(0));
YYABORT;
}
lex->sql_command=SQLCOM_KILL;
lex->thread_id= (ulong) $3->val_int();
};
};
kill_option:
kill_option:
...
...
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