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
d2bb9006
Commit
d2bb9006
authored
Oct 29, 2004
by
hf@deer.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merge abotchkov@bk-internal.mysql.com:/home/bk/mysql-4.1
into deer.(none):/home/hf/work/mysql-4.1.6117
parents
f4bc2e7f
541883f9
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
94 additions
and
102 deletions
+94
-102
mysql-test/r/alter_table.result
mysql-test/r/alter_table.result
+1
-0
mysql-test/r/ctype_recoding.result
mysql-test/r/ctype_recoding.result
+8
-0
mysql-test/r/fulltext.result
mysql-test/r/fulltext.result
+5
-0
mysql-test/t/alter_table.test
mysql-test/t/alter_table.test
+1
-0
mysql-test/t/ctype_recoding.test
mysql-test/t/ctype_recoding.test
+10
-0
scripts/make_win_src_distribution.sh
scripts/make_win_src_distribution.sh
+14
-12
sql/field.cc
sql/field.cc
+22
-10
sql/item_func.cc
sql/item_func.cc
+2
-2
sql/item_strfunc.cc
sql/item_strfunc.cc
+10
-52
sql/item_strfunc.h
sql/item_strfunc.h
+1
-19
sql/sql_string.cc
sql/sql_string.cc
+17
-4
sql/sql_string.h
sql/sql_string.h
+2
-2
sql/sql_yacc.yy
sql/sql_yacc.yy
+1
-1
No files found.
mysql-test/r/alter_table.result
View file @
d2bb9006
...
@@ -349,6 +349,7 @@ alter table t1 change a a char(10) character set koi8r;
...
@@ -349,6 +349,7 @@ alter table t1 change a a char(10) character set koi8r;
select a,hex(a) from t1;
select a,hex(a) from t1;
a hex(a)
a hex(a)
D4C5D3D4
D4C5D3D4
delete from t1;
show create table t1;
show create table t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
...
...
mysql-test/r/ctype_recoding.result
View file @
d2bb9006
...
@@ -166,3 +166,11 @@ ERROR HY000: Invalid utf8 character string: '
...
@@ -166,3 +166,11 @@ ERROR HY000: Invalid utf8 character string: '
SET NAMES utf8;
SET NAMES utf8;
CREATE TABLE `good` (a int);
CREATE TABLE `good` (a int);
ERROR HY000: Invalid utf8 character string: '` (a int)'
ERROR HY000: Invalid utf8 character string: '` (a int)'
set names latin1;
create table t1 (a char(10) character set koi8r, b text character set koi8r);
insert into t1 values ('test','test');
insert into t1 values ('','');
Warnings:
Warning 1265 Data truncated for column 'a' at row 1
Warning 1265 Data truncated for column 'b' at row 1
drop table t1;
mysql-test/r/fulltext.result
View file @
d2bb9006
...
@@ -356,6 +356,11 @@ SELECT t, collation(t),MATCH t AGAINST ('Osnabruck') FROM t1 WHERE MATCH t AGAIN
...
@@ -356,6 +356,11 @@ SELECT t, collation(t),MATCH t AGAINST ('Osnabruck') FROM t1 WHERE MATCH t AGAIN
t collation(t) MATCH t AGAINST ('Osnabruck')
t collation(t) MATCH t AGAINST ('Osnabruck')
aus Osnabrck utf8_general_ci 1.591139793396
aus Osnabrck utf8_general_ci 1.591139793396
alter table t1 modify t varchar(200) collate latin1_german2_ci not null;
alter table t1 modify t varchar(200) collate latin1_german2_ci not null;
Warnings:
Warning 1265 Data truncated for column 't' at row 3
Warning 1265 Data truncated for column 't' at row 4
Warning 1265 Data truncated for column 't' at row 5
Warning 1265 Data truncated for column 't' at row 6
SELECT t, collation(t) FROM t1 WHERE MATCH t AGAINST ('Osnabrck');
SELECT t, collation(t) FROM t1 WHERE MATCH t AGAINST ('Osnabrck');
t collation(t)
t collation(t)
aus Osnabrck latin1_german2_ci
aus Osnabrck latin1_german2_ci
...
...
mysql-test/t/alter_table.test
View file @
d2bb9006
...
@@ -207,6 +207,7 @@ alter table t1 change a a text character set cp1251;
...
@@ -207,6 +207,7 @@ alter table t1 change a a text character set cp1251;
select
a
,
hex
(
a
)
from
t1
;
select
a
,
hex
(
a
)
from
t1
;
alter
table
t1
change
a
a
char
(
10
)
character
set
koi8r
;
alter
table
t1
change
a
a
char
(
10
)
character
set
koi8r
;
select
a
,
hex
(
a
)
from
t1
;
select
a
,
hex
(
a
)
from
t1
;
delete
from
t1
;
#
#
# Test ALTER TABLE .. CHARACTER SET ..
# Test ALTER TABLE .. CHARACTER SET ..
...
...
mysql-test/t/ctype_recoding.test
View file @
d2bb9006
...
@@ -121,3 +121,13 @@ CREATE TABLE `good
...
@@ -121,3 +121,13 @@ CREATE TABLE `good
SET
NAMES
utf8
;
SET
NAMES
utf8
;
--
error
1300
--
error
1300
CREATE
TABLE
`good`
(
a
int
);
CREATE
TABLE
`good`
(
a
int
);
#
# Test that we produce a warnign when conversion loses data.
#
set
names
latin1
;
create
table
t1
(
a
char
(
10
)
character
set
koi8r
,
b
text
character
set
koi8r
);
insert
into
t1
values
(
'test'
,
'test'
);
insert
into
t1
values
(
''
,
''
);
drop
table
t1
;
scripts/make_win_src_distribution.sh
View file @
d2bb9006
...
@@ -6,7 +6,6 @@
...
@@ -6,7 +6,6 @@
version
=
@VERSION@
version
=
@VERSION@
export
version
export
version
SOURCE
=
`
pwd
`
CP
=
"cp -p"
CP
=
"cp -p"
DEBUG
=
0
DEBUG
=
0
...
@@ -24,6 +23,7 @@ if [ ! -f scripts/make_win_src_distribution ]; then
...
@@ -24,6 +23,7 @@ if [ ! -f scripts/make_win_src_distribution ]; then
echo
"ERROR : You must run this script from the MySQL top-level directory"
echo
"ERROR : You must run this script from the MySQL top-level directory"
exit
1
exit
1
fi
fi
SOURCE
=
`
pwd
`
#
#
# Check for source compilation/configuration
# Check for source compilation/configuration
...
@@ -119,7 +119,7 @@ unix_to_dos()
...
@@ -119,7 +119,7 @@ unix_to_dos()
for
arg
do
for
arg
do
print_debug
"Replacing LF -> CRLF from '
$arg
'"
print_debug
"Replacing LF -> CRLF from '
$arg
'"
cat
$arg
|
awk
'{sub(/$/,"\r");print}'
>
$arg
.tmp
awk
'{sub(/$/,"\r");print}'
<
$arg
>
$arg
.tmp
rm
-f
$arg
rm
-f
$arg
mv
$arg
.tmp
$arg
mv
$arg
.tmp
$arg
done
done
...
@@ -138,14 +138,6 @@ if [ -d $BASE ] ; then
...
@@ -138,14 +138,6 @@ if [ -d $BASE ] ; then
fi
fi
$CP
-r
$SOURCE
/VC++Files
$BASE
$CP
-r
$SOURCE
/VC++Files
$BASE
(
find
$BASE
\(
-name
"*.dsp"
-o
-name
"*.dsw"
\)
-and
-not
-path
\*
SCCS
\*
-print
)
|
(
while
read
v
do
unix_to_dos
$v
done
)
#
#
# Process version tags in InstallShield files
# Process version tags in InstallShield files
...
@@ -281,7 +273,6 @@ for i in COPYING ChangeLog README EXCEPTIONS-CLIENT\
...
@@ -281,7 +273,6 @@ for i in COPYING ChangeLog README EXCEPTIONS-CLIENT\
Docs/manual_toc.html Docs/manual.html
\
Docs/manual_toc.html Docs/manual.html
\
Docs/manual.txt Docs/mysqld_error.txt
\
Docs/manual.txt Docs/mysqld_error.txt
\
Docs/INSTALL-BINARY Docs/internals.texi
Docs/INSTALL-BINARY Docs/internals.texi
do
do
print_debug
"Copying file '
$i
'"
print_debug
"Copying file '
$i
'"
if
[
-f
$i
]
if
[
-f
$i
]
...
@@ -322,7 +313,18 @@ done
...
@@ -322,7 +313,18 @@ done
./extra/replace std::
""
<
$BASE
/sql/sql_yacc.cpp |
sed
'/^ *switch (yytype)$/ { N; /\n *{$/ { N; /\n *default:$/ { N; /\n *break;$/ { N; /\n *}$/ d; };};};} '
>
$BASE
/sql/sql_yacc.cpp-new
./extra/replace std::
""
<
$BASE
/sql/sql_yacc.cpp |
sed
'/^ *switch (yytype)$/ { N; /\n *{$/ { N; /\n *default:$/ { N; /\n *break;$/ { N; /\n *}$/ d; };};};} '
>
$BASE
/sql/sql_yacc.cpp-new
mv
$BASE
/sql/sql_yacc.cpp-new
$BASE
/sql/sql_yacc.cpp
mv
$BASE
/sql/sql_yacc.cpp-new
$BASE
/sql/sql_yacc.cpp
unix_to_dos
$BASE
/README
#
# Search the tree for plain text files and adapt the line end marker
#
find
$BASE
\(
-name
"*.dsp"
-o
-name
"*.dsw"
-o
-name
"*.cnf"
-o
-name
"*.ini"
\
-o
-name
COPYING
-o
-name
ChangeLog
-o
-name
EXCEPTIONS-CLIENT
-o
-name
"INSTALL*"
-o
-name
LICENSE
-o
-name
"README*"
\)
-type
f
-print
\
|
while
read
v
do
unix_to_dos
$v
done
# File extension '.txt' matches too many other files, error messages etc.
unix_to_dos
$BASE
/Docs/
*
.txt
mv
$BASE
/README
$BASE
/README.txt
mv
$BASE
/README
$BASE
/README.txt
#
#
...
...
sql/field.cc
View file @
d2bb9006
...
@@ -4275,9 +4275,12 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4275,9 +4275,12 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
/* Convert character set if nesessary */
/* Convert character set if nesessary */
if
(
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
&
not_used
))
if
(
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
&
not_used
))
{
{
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
);
uint
conv_errors
;
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
,
&
conv_errors
);
from
=
tmpstr
.
ptr
();
from
=
tmpstr
.
ptr
();
length
=
tmpstr
.
length
();
length
=
tmpstr
.
length
();
if
(
conv_errors
)
error
=
1
;
}
}
/*
/*
...
@@ -4300,11 +4303,11 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4300,11 +4303,11 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
from
+=
field_charset
->
cset
->
scan
(
field_charset
,
from
,
end
,
from
+=
field_charset
->
cset
->
scan
(
field_charset
,
from
,
end
,
MY_SEQ_SPACES
);
MY_SEQ_SPACES
);
if
(
from
!=
end
)
if
(
from
!=
end
)
{
error
=
1
;
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
error
=
1
;
}
}
}
if
(
error
)
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
return
error
;
return
error
;
}
}
...
@@ -4528,16 +4531,20 @@ int Field_varstring::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4528,16 +4531,20 @@ int Field_varstring::store(const char *from,uint length,CHARSET_INFO *cs)
/* Convert character set if nesessary */
/* Convert character set if nesessary */
if
(
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
&
not_used
))
if
(
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
&
not_used
))
{
{
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
);
uint
conv_errors
;
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
,
&
conv_errors
);
from
=
tmpstr
.
ptr
();
from
=
tmpstr
.
ptr
();
length
=
tmpstr
.
length
();
length
=
tmpstr
.
length
();
if
(
conv_errors
)
error
=
1
;
}
}
if
(
length
>
field_length
)
if
(
length
>
field_length
)
{
{
length
=
field_length
;
length
=
field_length
;
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
error
=
1
;
error
=
1
;
}
}
if
(
error
)
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
memcpy
(
ptr
+
HA_KEY_BLOB_LENGTH
,
from
,
length
);
memcpy
(
ptr
+
HA_KEY_BLOB_LENGTH
,
from
,
length
);
int2store
(
ptr
,
length
);
int2store
(
ptr
,
length
);
return
error
;
return
error
;
...
@@ -4865,6 +4872,7 @@ void Field_blob::put_length(char *pos, uint32 length)
...
@@ -4865,6 +4872,7 @@ void Field_blob::put_length(char *pos, uint32 length)
int
Field_blob
::
store
(
const
char
*
from
,
uint
length
,
CHARSET_INFO
*
cs
)
int
Field_blob
::
store
(
const
char
*
from
,
uint
length
,
CHARSET_INFO
*
cs
)
{
{
int
error
=
0
;
if
(
!
length
)
if
(
!
length
)
{
{
bzero
(
ptr
,
Field_blob
::
pack_length
());
bzero
(
ptr
,
Field_blob
::
pack_length
());
...
@@ -4881,9 +4889,12 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4881,9 +4889,12 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
if
((
was_conversion
=
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
if
((
was_conversion
=
String
::
needs_conversion
(
length
,
cs
,
field_charset
,
&
not_used
)))
&
not_used
)))
{
{
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
);
uint
conv_errors
;
tmpstr
.
copy
(
from
,
length
,
cs
,
field_charset
,
&
conv_errors
);
from
=
tmpstr
.
ptr
();
from
=
tmpstr
.
ptr
();
length
=
tmpstr
.
length
();
length
=
tmpstr
.
length
();
if
(
conv_errors
)
error
=
1
;
}
}
copy_length
=
max_data_length
();
copy_length
=
max_data_length
();
...
@@ -4897,8 +4908,7 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4897,8 +4908,7 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
min
(
length
,
copy_length
),
min
(
length
,
copy_length
),
copy_length
);
copy_length
);
if
(
copy_length
<
length
)
if
(
copy_length
<
length
)
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
error
=
1
;
Field_blob
::
store_length
(
copy_length
);
Field_blob
::
store_length
(
copy_length
);
if
(
was_conversion
||
table
->
copy_blobs
||
copy_length
<=
MAX_FIELD_WIDTH
)
if
(
was_conversion
||
table
->
copy_blobs
||
copy_length
<=
MAX_FIELD_WIDTH
)
{
// Must make a copy
{
// Must make a copy
...
@@ -4910,6 +4920,8 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -4910,6 +4920,8 @@ int Field_blob::store(const char *from,uint length,CHARSET_INFO *cs)
}
}
bmove
(
ptr
+
packlength
,(
char
*
)
&
from
,
sizeof
(
char
*
));
bmove
(
ptr
+
packlength
,(
char
*
)
&
from
,
sizeof
(
char
*
));
}
}
if
(
error
)
set_warning
(
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_WARN_DATA_TRUNCATED
,
1
);
return
0
;
return
0
;
}
}
...
...
sql/item_func.cc
View file @
d2bb9006
...
@@ -2873,10 +2873,10 @@ void Item_func_match::init_search(bool no_order)
...
@@ -2873,10 +2873,10 @@ void Item_func_match::init_search(bool no_order)
if
(
key
==
NO_SUCH_KEY
)
if
(
key
==
NO_SUCH_KEY
)
{
{
List
<
Item
>
fields
;
List
<
Item
>
fields
;
fields
.
push_back
(
new
Item_string
(
" "
,
1
,
cmp_collation
.
collation
));
for
(
uint
i
=
1
;
i
<
arg_count
;
i
++
)
for
(
uint
i
=
1
;
i
<
arg_count
;
i
++
)
fields
.
push_back
(
args
[
i
]);
fields
.
push_back
(
args
[
i
]);
concat
=
new
Item_func_concat_ws
(
new
Item_string
(
" "
,
1
,
concat
=
new
Item_func_concat_ws
(
fields
);
cmp_collation
.
collation
),
fields
);
/*
/*
Above function used only to get value and do not need fix_fields for it:
Above function used only to get value and do not need fix_fields for it:
Item_string - basic constant
Item_string - basic constant
...
...
sql/item_strfunc.cc
View file @
d2bb9006
...
@@ -532,7 +532,7 @@ String *Item_func_concat_ws::val_str(String *str)
...
@@ -532,7 +532,7 @@ String *Item_func_concat_ws::val_str(String *str)
uint
i
;
uint
i
;
null_value
=
0
;
null_value
=
0
;
if
(
!
(
sep_str
=
separator
->
val_str
(
&
tmp_sep_str
)))
if
(
!
(
sep_str
=
args
[
0
]
->
val_str
(
&
tmp_sep_str
)))
goto
null
;
goto
null
;
use_as_buff
=
&
tmp_value
;
use_as_buff
=
&
tmp_value
;
...
@@ -541,7 +541,7 @@ String *Item_func_concat_ws::val_str(String *str)
...
@@ -541,7 +541,7 @@ String *Item_func_concat_ws::val_str(String *str)
// Skip until non-null argument is found.
// Skip until non-null argument is found.
// If not, return the empty string
// If not, return the empty string
for
(
i
=
0
;
i
<
arg_count
;
i
++
)
for
(
i
=
1
;
i
<
arg_count
;
i
++
)
if
((
res
=
args
[
i
]
->
val_str
(
str
)))
if
((
res
=
args
[
i
]
->
val_str
(
str
)))
break
;
break
;
if
(
i
==
arg_count
)
if
(
i
==
arg_count
)
...
@@ -635,67 +635,25 @@ null:
...
@@ -635,67 +635,25 @@ null:
return
0
;
return
0
;
}
}
void
Item_func_concat_ws
::
split_sum_func
(
THD
*
thd
,
Item
**
ref_pointer_array
,
List
<
Item
>
&
fields
)
{
if
(
separator
->
with_sum_func
&&
separator
->
type
()
!=
SUM_FUNC_ITEM
)
separator
->
split_sum_func
(
thd
,
ref_pointer_array
,
fields
);
else
if
(
separator
->
used_tables
()
||
separator
->
type
()
==
SUM_FUNC_ITEM
)
{
uint
el
=
fields
.
elements
;
Item
*
new_item
=
new
Item_ref
(
ref_pointer_array
+
el
,
0
,
separator
->
name
);
fields
.
push_front
(
separator
);
ref_pointer_array
[
el
]
=
separator
;
thd
->
change_item_tree
(
&
separator
,
new_item
);
}
Item_str_func
::
split_sum_func
(
thd
,
ref_pointer_array
,
fields
);
}
void
Item_func_concat_ws
::
fix_length_and_dec
()
void
Item_func_concat_ws
::
fix_length_and_dec
()
{
{
collation
.
set
(
separator
->
collation
);
max_length
=
0
;
max_length
=
separator
->
max_length
*
(
arg_count
-
1
);
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
if
(
agg_arg_collations
(
collation
,
args
,
arg_count
))
{
return
;
DTCollation
tmp
(
collation
.
collation
,
collation
.
derivation
);
max_length
=
arg_count
>
1
?
args
[
0
]
->
max_length
*
(
arg_count
-
2
)
:
0
;
for
(
uint
i
=
1
;
i
<
arg_count
;
i
++
)
max_length
+=
args
[
i
]
->
max_length
;
max_length
+=
args
[
i
]
->
max_length
;
if
(
collation
.
aggregate
(
args
[
i
]
->
collation
))
{
collation
.
set
(
tmp
);
// Restore the previous value
my_coll_agg_error
(
collation
,
args
[
i
]
->
collation
,
func_name
());
break
;
}
}
if
(
max_length
>
MAX_BLOB_WIDTH
)
if
(
max_length
>
MAX_BLOB_WIDTH
)
{
{
max_length
=
MAX_BLOB_WIDTH
;
max_length
=
MAX_BLOB_WIDTH
;
maybe_null
=
1
;
maybe_null
=
1
;
}
}
used_tables_cache
|=
separator
->
used_tables
();
not_null_tables_cache
&=
separator
->
not_null_tables
();
const_item_cache
&=
separator
->
const_item
();
with_sum_func
=
with_sum_func
||
separator
->
with_sum_func
;
}
void
Item_func_concat_ws
::
update_used_tables
()
{
Item_func
::
update_used_tables
();
separator
->
update_used_tables
();
used_tables_cache
|=
separator
->
used_tables
();
const_item_cache
&=
separator
->
const_item
();
}
}
void
Item_func_concat_ws
::
print
(
String
*
str
)
{
str
->
append
(
"concat_ws("
,
10
);
separator
->
print
(
str
);
if
(
arg_count
)
{
str
->
append
(
','
);
print_args
(
str
,
0
);
}
str
->
append
(
')'
);
}
String
*
Item_func_reverse
::
val_str
(
String
*
str
)
String
*
Item_func_reverse
::
val_str
(
String
*
str
)
{
{
...
...
sql/item_strfunc.h
View file @
d2bb9006
...
@@ -89,30 +89,12 @@ public:
...
@@ -89,30 +89,12 @@ public:
class
Item_func_concat_ws
:
public
Item_str_func
class
Item_func_concat_ws
:
public
Item_str_func
{
{
Item
*
separator
;
String
tmp_value
;
String
tmp_value
;
public:
public:
Item_func_concat_ws
(
Item
*
a
,
List
<
Item
>
&
list
)
Item_func_concat_ws
(
List
<
Item
>
&
list
)
:
Item_str_func
(
list
)
{}
:
Item_str_func
(
list
),
separator
(
a
)
{}
String
*
val_str
(
String
*
);
String
*
val_str
(
String
*
);
void
fix_length_and_dec
();
void
fix_length_and_dec
();
void
update_used_tables
();
bool
fix_fields
(
THD
*
thd
,
TABLE_LIST
*
tlist
,
Item
**
ref
)
{
DBUG_ASSERT
(
fixed
==
0
);
return
(
separator
->
fix_fields
(
thd
,
tlist
,
&
separator
)
||
separator
->
check_cols
(
1
)
||
Item_func
::
fix_fields
(
thd
,
tlist
,
ref
));
}
void
split_sum_func
(
THD
*
thd
,
Item
**
ref_pointer_array
,
List
<
Item
>
&
fields
);
const
char
*
func_name
()
const
{
return
"concat_ws"
;
}
const
char
*
func_name
()
const
{
return
"concat_ws"
;
}
bool
walk
(
Item_processor
processor
,
byte
*
arg
)
{
return
separator
->
walk
(
processor
,
arg
)
||
Item_str_func
::
walk
(
processor
,
arg
);
}
void
print
(
String
*
str
);
};
};
class
Item_func_reverse
:
public
Item_str_func
class
Item_func_reverse
:
public
Item_str_func
...
...
sql/sql_string.cc
View file @
d2bb9006
...
@@ -331,19 +331,26 @@ bool String::set_or_copy_aligned(const char *str,uint32 arg_length,
...
@@ -331,19 +331,26 @@ bool String::set_or_copy_aligned(const char *str,uint32 arg_length,
/* Copy with charset convertion */
/* Copy with charset convertion */
bool
String
::
copy
(
const
char
*
str
,
uint32
arg_length
,
bool
String
::
copy
(
const
char
*
str
,
uint32
arg_length
,
CHARSET_INFO
*
from_cs
,
CHARSET_INFO
*
to_cs
)
CHARSET_INFO
*
from_cs
,
CHARSET_INFO
*
to_cs
,
uint
*
errors
)
{
{
uint32
offset
;
uint32
offset
;
if
(
!
needs_conversion
(
arg_length
,
from_cs
,
to_cs
,
&
offset
))
if
(
!
needs_conversion
(
arg_length
,
from_cs
,
to_cs
,
&
offset
))
{
if
(
errors
)
*
errors
=
0
;
return
copy
(
str
,
arg_length
,
to_cs
);
return
copy
(
str
,
arg_length
,
to_cs
);
}
if
((
from_cs
==
&
my_charset_bin
)
&&
offset
)
if
((
from_cs
==
&
my_charset_bin
)
&&
offset
)
{
if
(
errors
)
*
errors
=
0
;
return
copy_aligned
(
str
,
arg_length
,
offset
,
to_cs
);
return
copy_aligned
(
str
,
arg_length
,
offset
,
to_cs
);
}
uint32
new_length
=
to_cs
->
mbmaxlen
*
arg_length
;
uint32
new_length
=
to_cs
->
mbmaxlen
*
arg_length
;
if
(
alloc
(
new_length
))
if
(
alloc
(
new_length
))
return
TRUE
;
return
TRUE
;
str_length
=
copy_and_convert
((
char
*
)
Ptr
,
new_length
,
to_cs
,
str_length
=
copy_and_convert
((
char
*
)
Ptr
,
new_length
,
to_cs
,
str
,
arg_length
,
from_c
s
);
str
,
arg_length
,
from_cs
,
error
s
);
str_charset
=
to_cs
;
str_charset
=
to_cs
;
return
FALSE
;
return
FALSE
;
}
}
...
@@ -769,7 +776,8 @@ String *copy_if_not_alloced(String *to,String *from,uint32 from_length)
...
@@ -769,7 +776,8 @@ String *copy_if_not_alloced(String *to,String *from,uint32 from_length)
uint32
uint32
copy_and_convert
(
char
*
to
,
uint32
to_length
,
CHARSET_INFO
*
to_cs
,
copy_and_convert
(
char
*
to
,
uint32
to_length
,
CHARSET_INFO
*
to_cs
,
const
char
*
from
,
uint32
from_length
,
CHARSET_INFO
*
from_cs
)
const
char
*
from
,
uint32
from_length
,
CHARSET_INFO
*
from_cs
,
uint
*
errors
)
{
{
int
cnvres
;
int
cnvres
;
my_wc_t
wc
;
my_wc_t
wc
;
...
@@ -780,6 +788,7 @@ copy_and_convert(char *to, uint32 to_length, CHARSET_INFO *to_cs,
...
@@ -780,6 +788,7 @@ copy_and_convert(char *to, uint32 to_length, CHARSET_INFO *to_cs,
const
uchar
*
)
=
from_cs
->
cset
->
mb_wc
;
const
uchar
*
)
=
from_cs
->
cset
->
mb_wc
;
int
(
*
wc_mb
)(
struct
charset_info_st
*
,
my_wc_t
,
uchar
*
s
,
uchar
*
e
)
=
int
(
*
wc_mb
)(
struct
charset_info_st
*
,
my_wc_t
,
uchar
*
s
,
uchar
*
e
)
=
to_cs
->
cset
->
wc_mb
;
to_cs
->
cset
->
wc_mb
;
uint
error_count
=
0
;
while
(
1
)
while
(
1
)
{
{
...
@@ -788,6 +797,7 @@ copy_and_convert(char *to, uint32 to_length, CHARSET_INFO *to_cs,
...
@@ -788,6 +797,7 @@ copy_and_convert(char *to, uint32 to_length, CHARSET_INFO *to_cs,
from
+=
cnvres
;
from
+=
cnvres
;
else
if
(
cnvres
==
MY_CS_ILSEQ
)
else
if
(
cnvres
==
MY_CS_ILSEQ
)
{
{
error_count
++
;
from
++
;
from
++
;
wc
=
'?'
;
wc
=
'?'
;
}
}
...
@@ -799,12 +809,15 @@ outp:
...
@@ -799,12 +809,15 @@ outp:
to
+=
cnvres
;
to
+=
cnvres
;
else
if
(
cnvres
==
MY_CS_ILUNI
&&
wc
!=
'?'
)
else
if
(
cnvres
==
MY_CS_ILUNI
&&
wc
!=
'?'
)
{
{
error_count
++
;
wc
=
'?'
;
wc
=
'?'
;
goto
outp
;
goto
outp
;
}
}
else
else
break
;
break
;
}
}
if
(
errors
)
*
errors
=
error_count
;
return
(
uint32
)
(
to
-
to_start
);
return
(
uint32
)
(
to
-
to_start
);
}
}
...
...
sql/sql_string.h
View file @
d2bb9006
...
@@ -29,7 +29,7 @@ int sortcmp(const String *a,const String *b, CHARSET_INFO *cs);
...
@@ -29,7 +29,7 @@ int sortcmp(const String *a,const String *b, CHARSET_INFO *cs);
String
*
copy_if_not_alloced
(
String
*
a
,
String
*
b
,
uint32
arg_length
);
String
*
copy_if_not_alloced
(
String
*
a
,
String
*
b
,
uint32
arg_length
);
uint32
copy_and_convert
(
char
*
to
,
uint32
to_length
,
CHARSET_INFO
*
to_cs
,
uint32
copy_and_convert
(
char
*
to
,
uint32
to_length
,
CHARSET_INFO
*
to_cs
,
const
char
*
from
,
uint32
from_length
,
const
char
*
from
,
uint32
from_length
,
CHARSET_INFO
*
from_cs
);
CHARSET_INFO
*
from_cs
,
uint
*
errors
=
0
);
class
String
class
String
{
{
...
@@ -199,7 +199,7 @@ public:
...
@@ -199,7 +199,7 @@ public:
CHARSET_INFO
*
cs
);
CHARSET_INFO
*
cs
);
bool
set_or_copy_aligned
(
const
char
*
s
,
uint32
arg_length
,
CHARSET_INFO
*
cs
);
bool
set_or_copy_aligned
(
const
char
*
s
,
uint32
arg_length
,
CHARSET_INFO
*
cs
);
bool
copy
(
const
char
*
s
,
uint32
arg_length
,
CHARSET_INFO
*
csfrom
,
bool
copy
(
const
char
*
s
,
uint32
arg_length
,
CHARSET_INFO
*
csfrom
,
CHARSET_INFO
*
csto
);
CHARSET_INFO
*
csto
,
uint
*
errors
=
0
);
bool
append
(
const
String
&
s
);
bool
append
(
const
String
&
s
);
bool
append
(
const
char
*
s
);
bool
append
(
const
char
*
s
);
bool
append
(
const
char
*
s
,
uint32
arg_length
);
bool
append
(
const
char
*
s
,
uint32
arg_length
);
...
...
sql/sql_yacc.yy
View file @
d2bb9006
...
@@ -2889,7 +2889,7 @@ simple_expr:
...
@@ -2889,7 +2889,7 @@ simple_expr:
| CONCAT '(' expr_list ')'
| CONCAT '(' expr_list ')'
{ $$= new Item_func_concat(* $3); }
{ $$= new Item_func_concat(* $3); }
| CONCAT_WS '(' expr ',' expr_list ')'
| CONCAT_WS '(' expr ',' expr_list ')'
{ $
$= new Item_func_concat_ws($3,
*$5); }
{ $
5->push_front($3); $$= new Item_func_concat_ws(
*$5); }
| CONVERT_TZ_SYM '(' expr ',' expr ',' expr ')'
| CONVERT_TZ_SYM '(' expr ',' expr ',' expr ')'
{
{
Lex->time_zone_tables_used= &fake_time_zone_tables_list;
Lex->time_zone_tables_used= &fake_time_zone_tables_list;
...
...
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