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
b6da7f62
Commit
b6da7f62
authored
Jul 13, 2005
by
konstantin@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/opt/local/work/mysql-4.1-9379
into mysql.com:/opt/local/work/mysql-5.0-root
parents
a25c4ead
1755df76
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
51 additions
and
1 deletion
+51
-1
mysql-test/r/ps.result
mysql-test/r/ps.result
+19
-0
mysql-test/t/ps.test
mysql-test/t/ps.test
+15
-0
sql/item.cc
sql/item.cc
+3
-0
sql/item_func.cc
sql/item_func.cc
+14
-1
No files found.
mysql-test/r/ps.result
View file @
b6da7f62
...
...
@@ -740,3 +740,22 @@ execute stmt using @user_id, @id;
partner_id
deallocate prepare stmt;
drop table t1, t2, t3, t4;
prepare stmt from 'select ?=?';
set @a='CHRISTINE ';
set @b='CHRISTINE';
execute stmt using @a, @b;
?=?
1
execute stmt using @a, @b;
?=?
1
set @a=1, @b=2;
execute stmt using @a, @b;
?=?
0
set @a='CHRISTINE ';
set @b='CHRISTINE';
execute stmt using @a, @b;
?=?
1
deallocate prepare stmt;
mysql-test/t/ps.test
View file @
b6da7f62
...
...
@@ -773,3 +773,18 @@ execute stmt using @user_id, @id;
execute
stmt
using
@
user_id
,
@
id
;
deallocate
prepare
stmt
;
drop
table
t1
,
t2
,
t3
,
t4
;
#
# Bug#9379: make sure that Item::collation is reset when one sets
# a parameter marker from a string variable.
#
prepare
stmt
from
'select ?=?'
;
set
@
a
=
'CHRISTINE '
;
set
@
b
=
'CHRISTINE'
;
execute
stmt
using
@
a
,
@
b
;
execute
stmt
using
@
a
,
@
b
;
set
@
a
=
1
,
@
b
=
2
;
execute
stmt
using
@
a
,
@
b
;
set
@
a
=
'CHRISTINE '
;
set
@
b
=
'CHRISTINE'
;
execute
stmt
using
@
a
,
@
b
;
deallocate
prepare
stmt
;
sql/item.cc
View file @
b6da7f62
...
...
@@ -1942,6 +1942,7 @@ void Item_param::reset()
to the binary log.
*/
str_value
.
set_charset
(
&
my_charset_bin
);
collation
.
set
(
&
my_charset_bin
,
DERIVATION_COERCIBLE
);
state
=
NO_VALUE
;
maybe_null
=
1
;
null_value
=
0
;
...
...
@@ -2243,6 +2244,8 @@ bool Item_param::convert_str_value(THD *thd)
*/
str_value_ptr
.
set
(
str_value
.
ptr
(),
str_value
.
length
(),
str_value
.
charset
());
/* Synchronize item charset with value charset */
collation
.
set
(
str_value
.
charset
(),
DERIVATION_COERCIBLE
);
}
return
rc
;
}
...
...
sql/item_func.cc
View file @
b6da7f62
...
...
@@ -192,11 +192,24 @@ bool Item_func::agg_arg_charsets(DTCollation &coll,
}
if
((
*
arg
)
->
type
()
==
FIELD_ITEM
)
((
Item_field
*
)(
*
arg
))
->
no_const_subst
=
1
;
/*
If in statement prepare, then we create a converter for two
constant items, do it once and then reuse it.
If we're in execution of a prepared statement, arena is NULL,
and the conv was created in runtime memory. This can be
the case only if the argument is a parameter marker ('?'),
because for all true constants the charset converter has already
been created in prepare. In this case register the change for
rollback.
*/
if
(
arena
)
*
arg
=
conv
;
else
thd
->
change_item_tree
(
arg
,
conv
);
/*
We do not check conv->fixed, because Item_func_conv_charset which can
be return by safe_charset_converter can't be fixed at creation
*/
*
arg
=
conv
;
conv
->
fix_fields
(
thd
,
arg
);
}
if
(
arena
)
...
...
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