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
a04bfd8e
Commit
a04bfd8e
authored
Jun 26, 2006
by
konstantin@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/opt/local/work/tmp_merge
into mysql.com:/opt/local/work/mysql-5.1-runtime
parents
5e0a6927
40a1c179
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
147 additions
and
14 deletions
+147
-14
mysql-test/r/sp-prelocking.result
mysql-test/r/sp-prelocking.result
+18
-0
mysql-test/r/sp.result
mysql-test/r/sp.result
+21
-0
mysql-test/t/sp-prelocking.test
mysql-test/t/sp-prelocking.test
+30
-1
mysql-test/t/sp.test
mysql-test/t/sp.test
+27
-0
sql/sp_head.cc
sql/sp_head.cc
+3
-1
sql/sql_parse.cc
sql/sql_parse.cc
+36
-4
strings/ctype-mb.c
strings/ctype-mb.c
+12
-8
No files found.
mysql-test/r/sp-prelocking.result
View file @
a04bfd8e
...
@@ -237,3 +237,21 @@ deallocate prepare stmt;
...
@@ -237,3 +237,21 @@ deallocate prepare stmt;
drop table t1;
drop table t1;
drop view v1, v2, v3;
drop view v1, v2, v3;
drop function bug15683;
drop function bug15683;
drop table if exists t1, t2, t3;
drop function if exists bug19634;
create table t1 (id int, data int);
create table t2 (id int);
create table t3 (data int);
create function bug19634() returns int return (select count(*) from t3);
prepare stmt from "delete t1 from t1, t2 where t1.id = t2.id and bug19634()";
execute stmt;
execute stmt;
deallocate prepare stmt;
create trigger t1_bi before delete on t1 for each row insert into t3 values (old.data);
prepare stmt from "delete t1 from t1, t2 where t1.id = t2.id";
execute stmt;
execute stmt;
deallocate prepare stmt;
drop function bug19634;
drop table t1, t2, t3;
End of 5.0 tests
mysql-test/r/sp.result
View file @
a04bfd8e
...
@@ -5000,4 +5000,25 @@ CALL bug18037_p2()|
...
@@ -5000,4 +5000,25 @@ CALL bug18037_p2()|
DROP FUNCTION bug18037_f1|
DROP FUNCTION bug18037_f1|
DROP PROCEDURE bug18037_p1|
DROP PROCEDURE bug18037_p1|
DROP PROCEDURE bug18037_p2|
DROP PROCEDURE bug18037_p2|
drop table if exists t3|
drop procedure if exists bug15217|
create table t3 as select 1|
create procedure bug15217()
begin
declare var1 char(255);
declare cur1 cursor for select * from t3;
open cur1;
fetch cur1 into var1;
select concat('data was: /', var1, '/');
close cur1;
end |
call bug15217()|
concat('data was: /', var1, '/')
data was: /1/
flush tables |
call bug15217()|
concat('data was: /', var1, '/')
data was: /1/
drop table t3|
drop procedure bug15217|
drop table t1,t2;
drop table t1,t2;
mysql-test/t/sp-prelocking.test
View file @
a04bfd8e
...
@@ -271,6 +271,35 @@ deallocate prepare stmt;
...
@@ -271,6 +271,35 @@ deallocate prepare stmt;
drop
table
t1
;
drop
table
t1
;
drop
view
v1
,
v2
,
v3
;
drop
view
v1
,
v2
,
v3
;
drop
function
bug15683
;
drop
function
bug15683
;
#
#
# End of 5.0 tests
# Bug#19634 "Re-execution of multi-delete which involve trigger/stored
# function crashes server"
#
#
--
disable_warnings
drop
table
if
exists
t1
,
t2
,
t3
;
drop
function
if
exists
bug19634
;
--
enable_warnings
create
table
t1
(
id
int
,
data
int
);
create
table
t2
(
id
int
);
create
table
t3
(
data
int
);
create
function
bug19634
()
returns
int
return
(
select
count
(
*
)
from
t3
);
prepare
stmt
from
"delete t1 from t1, t2 where t1.id = t2.id and bug19634()"
;
# This should not crash server
execute
stmt
;
execute
stmt
;
deallocate
prepare
stmt
;
create
trigger
t1_bi
before
delete
on
t1
for
each
row
insert
into
t3
values
(
old
.
data
);
prepare
stmt
from
"delete t1 from t1, t2 where t1.id = t2.id"
;
execute
stmt
;
execute
stmt
;
deallocate
prepare
stmt
;
drop
function
bug19634
;
drop
table
t1
,
t2
,
t3
;
--
echo
End
of
5.0
tests
mysql-test/t/sp.test
View file @
a04bfd8e
...
@@ -5893,6 +5893,33 @@ DROP FUNCTION bug18037_f1|
...
@@ -5893,6 +5893,33 @@ DROP FUNCTION bug18037_f1|
DROP
PROCEDURE
bug18037_p1
|
DROP
PROCEDURE
bug18037_p1
|
DROP
PROCEDURE
bug18037_p2
|
DROP
PROCEDURE
bug18037_p2
|
#
# Bug#15217 "Using a SP cursor on a table created with PREPARE fails with
# weird error". Check that the code that is supposed to work at
# the first execution of a stored procedure actually works for
# sp_instr_copen.
--
disable_warnings
drop
table
if
exists
t3
|
drop
procedure
if
exists
bug15217
|
--
enable_warnings
create
table
t3
as
select
1
|
create
procedure
bug15217
()
begin
declare
var1
char
(
255
);
declare
cur1
cursor
for
select
*
from
t3
;
open
cur1
;
fetch
cur1
into
var1
;
select
concat
(
'data was: /'
,
var1
,
'/'
);
close
cur1
;
end
|
# Returns expected result
call
bug15217
()
|
flush
tables
|
# Returns error with garbage as column name
call
bug15217
()
|
drop
table
t3
|
drop
procedure
bug15217
|
#
#
# BUG#NNNN: New bug synopsis
# BUG#NNNN: New bug synopsis
...
...
sql/sp_head.cc
View file @
a04bfd8e
...
@@ -1091,7 +1091,6 @@ sp_head::execute(THD *thd)
...
@@ -1091,7 +1091,6 @@ sp_head::execute(THD *thd)
thd
->
net
.
no_send_error
=
0
;
thd
->
net
.
no_send_error
=
0
;
if
(
i
->
free_list
)
if
(
i
->
free_list
)
cleanup_items
(
i
->
free_list
);
cleanup_items
(
i
->
free_list
);
i
->
state
=
Query_arena
::
EXECUTED
;
/*
/*
If we've set thd->user_var_events_alloc to mem_root of this SP
If we've set thd->user_var_events_alloc to mem_root of this SP
...
@@ -2252,6 +2251,9 @@ sp_lex_keeper::reset_lex_and_exec_core(THD *thd, uint *nextp,
...
@@ -2252,6 +2251,9 @@ sp_lex_keeper::reset_lex_and_exec_core(THD *thd, uint *nextp,
m_lex
->
mark_as_requiring_prelocking
(
NULL
);
m_lex
->
mark_as_requiring_prelocking
(
NULL
);
}
}
thd
->
rollback_item_tree_changes
();
thd
->
rollback_item_tree_changes
();
/* Update the state of the active arena. */
thd
->
stmt_arena
->
state
=
Query_arena
::
EXECUTED
;
/*
/*
Unlike for PS we should not call Item's destructors for newly created
Unlike for PS we should not call Item's destructors for newly created
...
...
sql/sql_parse.cc
View file @
a04bfd8e
...
@@ -5469,8 +5469,26 @@ bool check_global_access(THD *thd, ulong want_access)
...
@@ -5469,8 +5469,26 @@ bool check_global_access(THD *thd, ulong want_access)
/*
/*
Check the privilege for all used tables. Table privileges are cached
Check the privilege for all used tables.
in the table list for GRANT checking
SYNOPSYS
check_table_access()
thd Thread context
want_access Privileges requested
tables List of tables to be checked
no_errors FALSE/TRUE - report/don't report error to
the client (using my_error() call).
NOTES
Table privileges are cached in the table list for GRANT checking.
This functions assumes that table list used and
thd->lex->query_tables_own_last value correspond to each other
(the latter should be either 0 or point to next_global member
of one of elements of this table list).
RETURN VALUE
FALSE - OK
TRUE - Access denied
*/
*/
bool
bool
...
@@ -7383,14 +7401,28 @@ bool multi_delete_precheck(THD *thd, TABLE_LIST *tables)
...
@@ -7383,14 +7401,28 @@ bool multi_delete_precheck(THD *thd, TABLE_LIST *tables)
SELECT_LEX
*
select_lex
=
&
thd
->
lex
->
select_lex
;
SELECT_LEX
*
select_lex
=
&
thd
->
lex
->
select_lex
;
TABLE_LIST
*
aux_tables
=
TABLE_LIST
*
aux_tables
=
(
TABLE_LIST
*
)
thd
->
lex
->
auxilliary_table_list
.
first
;
(
TABLE_LIST
*
)
thd
->
lex
->
auxilliary_table_list
.
first
;
TABLE_LIST
**
save_query_tables_own_last
=
thd
->
lex
->
query_tables_own_last
;
DBUG_ENTER
(
"multi_delete_precheck"
);
DBUG_ENTER
(
"multi_delete_precheck"
);
/* sql_yacc guarantees that tables and aux_tables are not zero */
/* sql_yacc guarantees that tables and aux_tables are not zero */
DBUG_ASSERT
(
aux_tables
!=
0
);
DBUG_ASSERT
(
aux_tables
!=
0
);
if
(
check_db_used
(
thd
,
tables
)
||
check_db_used
(
thd
,
aux_tables
)
||
if
(
check_db_used
(
thd
,
tables
)
||
check_db_used
(
thd
,
aux_tables
)
||
check_table_access
(
thd
,
SELECT_ACL
,
tables
,
0
)
||
check_table_access
(
thd
,
SELECT_ACL
,
tables
,
0
))
check_table_access
(
thd
,
DELETE_ACL
,
aux_tables
,
0
))
DBUG_RETURN
(
TRUE
);
/*
Since aux_tables list is not part of LEX::query_tables list we
have to juggle with LEX::query_tables_own_last value to be able
call check_table_access() safely.
*/
thd
->
lex
->
query_tables_own_last
=
0
;
if
(
check_table_access
(
thd
,
DELETE_ACL
,
aux_tables
,
0
))
{
thd
->
lex
->
query_tables_own_last
=
save_query_tables_own_last
;
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
}
thd
->
lex
->
query_tables_own_last
=
save_query_tables_own_last
;
if
((
thd
->
options
&
OPTION_SAFE_UPDATES
)
&&
!
select_lex
->
where
)
if
((
thd
->
options
&
OPTION_SAFE_UPDATES
)
&&
!
select_lex
->
where
)
{
{
my_message
(
ER_UPDATE_WITHOUT_KEY_IN_SAFE_MODE
,
my_message
(
ER_UPDATE_WITHOUT_KEY_IN_SAFE_MODE
,
...
...
strings/ctype-mb.c
View file @
a04bfd8e
...
@@ -24,12 +24,12 @@
...
@@ -24,12 +24,12 @@
void
my_caseup_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
void
my_caseup_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uint32
l
;
register
uint32
l
;
register
char
*
end
=
str
+
strlen
(
str
);
/* BAR TODO: remove strlen() call */
register
uchar
*
map
=
cs
->
to_upper
;
register
uchar
*
map
=
cs
->
to_upper
;
while
(
*
str
)
while
(
*
str
)
{
{
if
((
l
=
my_ismbchar
(
cs
,
str
,
end
)))
/* Pointing after the '\0' is safe here. */
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
str
+=
l
;
str
+=
l
;
else
else
{
{
...
@@ -42,12 +42,12 @@ void my_caseup_str_mb(CHARSET_INFO * cs, char *str)
...
@@ -42,12 +42,12 @@ void my_caseup_str_mb(CHARSET_INFO * cs, char *str)
void
my_casedn_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
void
my_casedn_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uint32
l
;
register
uint32
l
;
register
char
*
end
=
str
+
strlen
(
str
);
register
uchar
*
map
=
cs
->
to_lower
;
register
uchar
*
map
=
cs
->
to_lower
;
while
(
*
str
)
while
(
*
str
)
{
{
if
((
l
=
my_ismbchar
(
cs
,
str
,
end
)))
/* Pointing after the '\0' is safe here. */
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
str
+=
l
;
str
+=
l
;
else
else
{
{
...
@@ -101,15 +101,18 @@ uint my_casedn_mb(CHARSET_INFO * cs, char *src, uint srclen,
...
@@ -101,15 +101,18 @@ uint my_casedn_mb(CHARSET_INFO * cs, char *src, uint srclen,
return
srclen
;
return
srclen
;
}
}
/*
my_strcasecmp_mb() returns 0 if strings are equal, non-zero otherwise.
*/
int
my_strcasecmp_mb
(
CHARSET_INFO
*
cs
,
const
char
*
s
,
const
char
*
t
)
int
my_strcasecmp_mb
(
CHARSET_INFO
*
cs
,
const
char
*
s
,
const
char
*
t
)
{
{
register
uint32
l
;
register
uint32
l
;
register
const
char
*
end
=
s
+
strlen
(
s
);
register
uchar
*
map
=
cs
->
to_upper
;
register
uchar
*
map
=
cs
->
to_upper
;
while
(
s
<
end
)
while
(
*
s
&&
*
t
)
{
{
if
((
l
=
my_ismbchar
(
cs
,
s
,
end
)))
/* Pointing after the '\0' is safe here. */
if
((
l
=
my_ismbchar
(
cs
,
s
,
s
+
cs
->
mbmaxlen
)))
{
{
while
(
l
--
)
while
(
l
--
)
if
(
*
s
++
!=
*
t
++
)
if
(
*
s
++
!=
*
t
++
)
...
@@ -120,7 +123,8 @@ int my_strcasecmp_mb(CHARSET_INFO * cs,const char *s, const char *t)
...
@@ -120,7 +123,8 @@ int my_strcasecmp_mb(CHARSET_INFO * cs,const char *s, const char *t)
else
if
(
map
[(
uchar
)
*
s
++
]
!=
map
[(
uchar
)
*
t
++
])
else
if
(
map
[(
uchar
)
*
s
++
]
!=
map
[(
uchar
)
*
t
++
])
return
1
;
return
1
;
}
}
return
*
t
;
/* At least one of '*s' and '*t' is zero here. */
return
(
*
t
!=
*
s
);
}
}
...
...
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