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
a8b38dd7
Commit
a8b38dd7
authored
Sep 13, 2004
by
serg@serg.mylan
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-4.1/
into serg.mylan:/usr/home/serg/Abk/mysql-4.1
parents
962c228a
ca0fc0b4
Changes
19
Hide whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
825 additions
and
42 deletions
+825
-42
client/mysql.cc
client/mysql.cc
+16
-17
configure.in
configure.in
+2
-2
libmysql/libmysql.c
libmysql/libmysql.c
+5
-5
mysql-test/r/ctype_uca.result
mysql-test/r/ctype_uca.result
+374
-0
mysql-test/r/func_set.result
mysql-test/r/func_set.result
+3
-0
mysql-test/r/order_by.result
mysql-test/r/order_by.result
+13
-0
mysql-test/t/ctype_uca.test
mysql-test/t/ctype_uca.test
+191
-0
mysql-test/t/func_set.test
mysql-test/t/func_set.test
+5
-0
mysql-test/t/order_by.test
mysql-test/t/order_by.test
+13
-0
mysys/charset-def.c
mysys/charset-def.c
+4
-0
sql/examples/ha_tina.h
sql/examples/ha_tina.h
+6
-0
sql/filesort.cc
sql/filesort.cc
+79
-6
sql/ha_berkeley.cc
sql/ha_berkeley.cc
+3
-3
sql/ha_berkeley.h
sql/ha_berkeley.h
+1
-1
sql/ha_innodb.cc
sql/ha_innodb.cc
+3
-3
sql/ha_innodb.h
sql/ha_innodb.h
+1
-1
sql/handler.h
sql/handler.h
+9
-1
sql/item_func.cc
sql/item_func.cc
+3
-2
strings/ctype-uca.c
strings/ctype-uca.c
+94
-1
No files found.
client/mysql.cc
View file @
a8b38dd7
...
@@ -2834,25 +2834,13 @@ com_status(String *buffer __attribute__((unused)),
...
@@ -2834,25 +2834,13 @@ com_status(String *buffer __attribute__((unused)),
const
char
*
status
;
const
char
*
status
;
char
buff
[
22
];
char
buff
[
22
];
ulonglong
id
;
ulonglong
id
;
MYSQL_RES
*
result
;
LINT_INIT
(
result
);
tee_puts
(
"--------------"
,
stdout
);
tee_puts
(
"--------------"
,
stdout
);
usage
(
1
);
/* Print version */
usage
(
1
);
/* Print version */
if
(
connected
)
if
(
connected
)
{
{
MYSQL_RES
*
result
;
LINT_INIT
(
result
);
tee_fprintf
(
stdout
,
"
\n
Connection id:
\t\t
%lu
\n
"
,
mysql_thread_id
(
&
mysql
));
if
(
!
mysql_query
(
&
mysql
,
"select DATABASE(), USER() limit 1"
)
&&
(
result
=
mysql_use_result
(
&
mysql
)))
{
MYSQL_ROW
cur
=
mysql_fetch_row
(
result
);
if
(
cur
)
{
tee_fprintf
(
stdout
,
"Current database:
\t
%s
\n
"
,
cur
[
0
]
?
cur
[
0
]
:
""
);
tee_fprintf
(
stdout
,
"Current user:
\t\t
%s
\n
"
,
cur
[
1
]);
}
mysql_free_result
(
result
);
}
#ifdef HAVE_OPENSSL
#ifdef HAVE_OPENSSL
if
(
mysql
.
net
.
vio
&&
mysql
.
net
.
vio
->
ssl_arg
&&
if
(
mysql
.
net
.
vio
&&
mysql
.
net
.
vio
->
ssl_arg
&&
SSL_get_cipher
((
SSL
*
)
mysql
.
net
.
vio
->
ssl_arg
))
SSL_get_cipher
((
SSL
*
)
mysql
.
net
.
vio
->
ssl_arg
))
...
@@ -2886,9 +2874,20 @@ com_status(String *buffer __attribute__((unused)),
...
@@ -2886,9 +2874,20 @@ com_status(String *buffer __attribute__((unused)),
if
((
id
=
mysql_insert_id
(
&
mysql
)))
if
((
id
=
mysql_insert_id
(
&
mysql
)))
tee_fprintf
(
stdout
,
"Insert id:
\t\t
%s
\n
"
,
llstr
(
id
,
buff
));
tee_fprintf
(
stdout
,
"Insert id:
\t\t
%s
\n
"
,
llstr
(
id
,
buff
));
tee_fprintf
(
stdout
,
"Client characterset:
\t
%s
\n
"
,
if
(
!
mysql_query
(
&
mysql
,
"select @@character_set_client, @@character_set_connection, @@character_set_server, @@character_set_database"
)
&&
charset_info
->
name
);
(
result
=
mysql_use_result
(
&
mysql
)))
tee_fprintf
(
stdout
,
"Server characterset:
\t
%s
\n
"
,
mysql
.
charset
->
name
);
{
MYSQL_ROW
cur
=
mysql_fetch_row
(
result
);
if
(
cur
)
{
tee_fprintf
(
stdout
,
"Server characterset:
\t
%s
\n
"
,
cur
[
0
]
?
cur
[
0
]
:
""
);
tee_fprintf
(
stdout
,
"Db characterset:
\t
%s
\n
"
,
cur
[
3
]
?
cur
[
3
]
:
""
);
tee_fprintf
(
stdout
,
"Client characterset:
\t
%s
\n
"
,
cur
[
2
]
?
cur
[
2
]
:
""
);
tee_fprintf
(
stdout
,
"Conn. characterset:
\t
%s
\n
"
,
cur
[
1
]
?
cur
[
1
]
:
""
);
}
mysql_free_result
(
result
);
}
#ifndef EMBEDDED_LIBRARY
#ifndef EMBEDDED_LIBRARY
if
(
strstr
(
mysql_get_host_info
(
&
mysql
),
"TCP/IP"
)
||
!
mysql
.
unix_socket
)
if
(
strstr
(
mysql_get_host_info
(
&
mysql
),
"TCP/IP"
)
||
!
mysql
.
unix_socket
)
tee_fprintf
(
stdout
,
"TCP port:
\t\t
%d
\n
"
,
mysql
.
port
);
tee_fprintf
(
stdout
,
"TCP port:
\t\t
%d
\n
"
,
mysql
.
port
);
...
...
configure.in
View file @
a8b38dd7
...
@@ -2715,7 +2715,7 @@ case $default_charset in
...
@@ -2715,7 +2715,7 @@ case $default_charset in
define
(
UCSC2, ucs2_czech_ci ucs2_danish_ci
)
define
(
UCSC2, ucs2_czech_ci ucs2_danish_ci
)
define
(
UCSC3, ucs2_estonian_ci ucs2_icelandic_ci
)
define
(
UCSC3, ucs2_estonian_ci ucs2_icelandic_ci
)
define
(
UCSC4, ucs2_latvian_ci ucs2_lithuanian_ci
)
define
(
UCSC4, ucs2_latvian_ci ucs2_lithuanian_ci
)
define
(
UCSC5, ucs2_polish_ci ucs2_romanian_ci
)
define
(
UCSC5, ucs2_p
ersian_ci ucs2_p
olish_ci ucs2_romanian_ci
)
define
(
UCSC6, ucs2_slovak_ci ucs2_slovenian_ci
)
define
(
UCSC6, ucs2_slovak_ci ucs2_slovenian_ci
)
define
(
UCSC7, ucs2_spanish2_ci ucs2_spanish_ci
)
define
(
UCSC7, ucs2_spanish2_ci ucs2_spanish_ci
)
define
(
UCSC8, ucs2_swedish_ci ucs2_turkish_ci
)
define
(
UCSC8, ucs2_swedish_ci ucs2_turkish_ci
)
...
@@ -2733,7 +2733,7 @@ case $default_charset in
...
@@ -2733,7 +2733,7 @@ case $default_charset in
define
(
UTFC2, utf8_czech_ci utf8_danish_ci
)
define
(
UTFC2, utf8_czech_ci utf8_danish_ci
)
define
(
UTFC3, utf8_estonian_ci utf8_icelandic_ci
)
define
(
UTFC3, utf8_estonian_ci utf8_icelandic_ci
)
define
(
UTFC4, utf8_latvian_ci utf8_lithuanian_ci
)
define
(
UTFC4, utf8_latvian_ci utf8_lithuanian_ci
)
define
(
UTFC5, utf8_polish_ci utf8_romanian_ci
)
define
(
UTFC5, utf8_p
ersian_ci utf8_p
olish_ci utf8_romanian_ci
)
define
(
UTFC6, utf8_slovak_ci utf8_slovenian_ci
)
define
(
UTFC6, utf8_slovak_ci utf8_slovenian_ci
)
define
(
UTFC7, utf8_spanish2_ci utf8_spanish_ci
)
define
(
UTFC7, utf8_spanish2_ci utf8_spanish_ci
)
define
(
UTFC8, utf8_swedish_ci utf8_turkish_ci
)
define
(
UTFC8, utf8_swedish_ci utf8_turkish_ci
)
...
...
libmysql/libmysql.c
View file @
a8b38dd7
...
@@ -1860,14 +1860,14 @@ MYSQL_STMT * STDCALL mysql_prepare(MYSQL *mysql, const char *query,
...
@@ -1860,14 +1860,14 @@ MYSQL_STMT * STDCALL mysql_prepare(MYSQL *mysql, const char *query,
a server-side prepared statement. Memory for this structure (~700
a server-side prepared statement. Memory for this structure (~700
bytes) is allocated using 'malloc'. Once created, the handle can be
bytes) is allocated using 'malloc'. Once created, the handle can be
reused many times. Created statement handle is bound to connection
reused many times. Created statement handle is bound to connection
handle provided to this call: it
'
s lifetime is limited by lifetime
handle provided to this call: its lifetime is limited by lifetime
of connection.
of connection.
'mysql_stmt_init()' is a pure local call, server side structure is
'mysql_stmt_init()' is a pure local call, server side structure is
created only in mysql_stmt_prepare.
created only in mysql_stmt_prepare.
Next steps you may want to make:
Next steps you may want to make:
- set a statement attribute (mysql_stmt_attr_set()),
- set a statement attribute (mysql_stmt_attr_set()),
- prepare statement handle with a query (mysql_stmt_prepare()),
- prepare statement handle with a query (mysql_stmt_prepare()),
- close statement handle and free it
'
s memory (mysql_stmt_close()),
- close statement handle and free its memory (mysql_stmt_close()),
- reset statement with mysql_stmt_reset() (a no-op which will
- reset statement with mysql_stmt_reset() (a no-op which will
just return).
just return).
Behaviour of the rest of API calls on this statement is not defined yet
Behaviour of the rest of API calls on this statement is not defined yet
...
@@ -2592,7 +2592,7 @@ stmt_read_row_no_data(MYSQL_STMT *stmt __attribute__((unused)),
...
@@ -2592,7 +2592,7 @@ stmt_read_row_no_data(MYSQL_STMT *stmt __attribute__((unused)),
mysql_stmt_attr_get()
mysql_stmt_attr_get()
mysql_stmt_attr_set()
mysql_stmt_attr_set()
attr_type statemen
e
t attribute
attr_type statement attribute
value casted to const void * pointer to value.
value casted to const void * pointer to value.
RETURN VALUE
RETURN VALUE
...
@@ -2688,7 +2688,7 @@ int STDCALL mysql_stmt_execute(MYSQL_STMT *stmt)
...
@@ -2688,7 +2688,7 @@ int STDCALL mysql_stmt_execute(MYSQL_STMT *stmt)
mysql_stmt_free_result
(
stmt
);
mysql_stmt_free_result
(
stmt
);
/*
/*
No need to check for stmt->state: if the statement wasn't
No need to check for stmt->state: if the statement wasn't
prepared we'll get 'unknown statemen
e
t handler' error from server.
prepared we'll get 'unknown statement handler' error from server.
*/
*/
if
(
mysql
->
methods
->
stmt_execute
(
stmt
))
if
(
mysql
->
methods
->
stmt_execute
(
stmt
))
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
...
@@ -2813,7 +2813,7 @@ static my_bool int_is_null_false= 0;
...
@@ -2813,7 +2813,7 @@ static my_bool int_is_null_false= 0;
By properly initializing bind array you can bind virtually any
By properly initializing bind array you can bind virtually any
C language type to statement's placeholders:
C language type to statement's placeholders:
First, it's strongly recommended to always zero-initialize entire
First, it's strongly recommended to always zero-initialize entire
bind structure before setting it
'
s members. This will both shorten
bind structure before setting its members. This will both shorten
your application code and make it robust to future extensions of
your application code and make it robust to future extensions of
MYSQL_BIND structure.
MYSQL_BIND structure.
Then you need to assign typecode of your application buffer to
Then you need to assign typecode of your application buffer to
...
...
mysql-test/r/ctype_uca.result
View file @
a8b38dd7
...
@@ -1911,3 +1911,377 @@ c
...
@@ -1911,3 +1911,377 @@ c
Μωδ
Μωδ
Μωδαί̈
Μωδαί̈
DROP TABLE t1;
DROP TABLE t1;
CREATE TABLE t1 (
col1 CHAR(32) CHARACTER SET utf8 NOT NULL
);
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0041004100410627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0041004100410628 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0041004100410647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0041004100410648 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0633064A0651062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062D06330646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0642064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06320627062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062806310627064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064706450647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F062706460634062C0648064A06270646064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A90647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A06270631064A062E USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062706460642064406270628 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A0631062706460650 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627062F064806270631062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280631062706480646200C06310627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062E064806270646062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0648 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A062D062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0623062B064A0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06220646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0642063106270631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06AF06310641062A0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270646062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0634062E0635064A0651062A064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628062706310632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270633062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063906A90633 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270648060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062D062F0648062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628064A0633062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0648067E0646062C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06330627064406AF064A060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063306270644 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606450627064A0646062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A06280631064A0632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645062C06440633 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280648062F060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628064A0646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06350641062D0627062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A0646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A9062A06270628 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x068606340645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062E06480631062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0686064706310647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06420648064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450635064506510645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06310627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0646063406270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645064A200C062F0647062F060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0647063106860646062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06390645064400BB USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A9064806340634 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064706500646064A064606AF USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627062D063306270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064A062706310634062706370631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450646062A06340631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0634062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F0633062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A064806270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0647064506270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064806510644 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0634062E064A0635 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F0627062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A064106270648062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062D06270644062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A064106A906510631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063A064406280647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F06270631062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064A06A9064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063106470628063106270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606470636062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064506340631064806370647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A063106270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0646064A0632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064A06A9 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645062D064206510642 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0637063106270632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064106310647064606AF USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0645062F06510646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A063106270646064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280648062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A90627063106470627064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270648 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0639063106350647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064506480631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0633064A06270633064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064A063106270646060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062D064806320647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063906440645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F062706460634 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450642062706440627062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F064A06AF0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0648064A06980647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0646062706450647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064506480631062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628062D062B USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0628063106310633064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606480634062A0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A064606470627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0622064606860647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F064806310647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064206270645062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x067E0631062F062706320645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0698062706460648064A0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0648064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F06390648062A0650 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063306500631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F0646064A0633064F0646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063106270633 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0647064A0626062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0639064406480645200C063406310642064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280639062F0627064B USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645062F063106330647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062206410631064A06420627064A064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F06270646063406AF06270647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06440646062F0646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x067E064A06480633062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0647064606AF06270645064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x067E0633 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0622063A06270632 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062C064606AF USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062C064706270646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F064806510645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063406470631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A9064506280631064A062C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450646062A06420644 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A90631062F0646062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06470645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06310641062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06220646062C0627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064506270646062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0627 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062706A9062A06280631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606380631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F06480644062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F06480628062706310647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606330628062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645063306270639062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0634062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06480632064A0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0645062E062A06270631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06330641064A0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627064606AF0644064A0633 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0642064A200C06320627062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280627063206AF0634062A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0647064506330631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06220644064506270646064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06270634 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06220645062F0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A906270631064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x067E0631062F0627062E062A0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063906440645064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x0627062F0628064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062D062F0651 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064606280648062F060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06480644064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x063906480636060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06340627064A062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064506470645 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062A0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06220646060C USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06470645063306310634 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A90627064606480646 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062E0627064606480627062F06AF064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06AF06310645064A USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280648062C0648062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062206480631062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F0648 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06A90627064506440627064B USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x064A06A9062F064A06AF0631 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06AF USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x062F064406280633062A0647 USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06280648062F0646062F USING utf8));
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x06450647064506270646 USING utf8));
SELECT HEX(CONVERT(col1 USING ucs2)) FROM t1 ORDER BY col1 COLLATE utf8_persian_ci, col1 COLLATE utf8_bin;
HEX(CONVERT(col1 USING ucs2))
0041004100410627
0041004100410628
0041004100410648
0041004100410647
0622063A06270632
062206410631064A06420627064A064A
06220644064506270646064A
06220645062F0647
06220646
06220646060C
06220646062C0627
0622064606860647
062206480631062F
0627062D063306270646
0627062F0628064A
0627062F064806270631062F
06270632
06270633062A
06270634
0627064206270645062A
062706A9062A06280631
0627064506480631
06270646062F
062706460642064406270628
0627064606AF0644064A0633
06270648
06270648060C
0627064806510644
0627064A
0627064A063106270646
0627064A063106270646060C
0627064A0631062706460650
0627064A063106270646064A
0627064A0646
0628
06280627
0628062706310632
06280627063206AF0634062A
0628062D062B
06280631062706480646200C06310627
062806310627064A
0628063106310633064A
06280639062F0627064B
06280648062C0648062F
06280648062F
06280648062F060C
06280648062F0646062F
06280647
0628064A0633062A
0628064A0646
067E0631062F0627062E062A0647
067E0631062F062706320645
067E0633
067E064A06480633062A
062A0627
062A06270631064A062E
062A0623062B064A0631
062A06280631064A0632
062A062D062A
062A0631
062A0634062E064A0635
062A064106270648062A
062A064106A906510631
062A0642064A
062A0642064A200C06320627062F0647
062A0645062F06510646
062A064606470627
062A064806270646
062C064606AF
062C064706270646
068606340645
0686064706310647
062D06270644062A
062D062F0651
062D062F0648062F
062D06330646
062D064806320647
062E0627064606480627062F06AF064A
062E064806270646062F0647
062E06480631062F
062F0627062F
062F06270631062F
062F062706460634
062F062706460634062C0648064A06270646064A
062F06270646063406AF06270647
062F0631
062F0633062A
062F06390648062A0650
062F064406280633062A0647
062F0646064A0633064F0646
062F0648
062F06480628062706310647
062F064806310647
062F06480644062A
062F064806510645
062F064A06AF0631
06310627
063106270633
06310641062A
063106470628063106270646
06320627062F0647
0698062706460648064A0647
063306500631
063306270644
06330627064406AF064A060C
06330641064A0631
0633064A06270633064A
0633064A0651062F
06340627064A062F
0634062E0635064A0651062A064A
0634062F
0634062F0647
063406470631
06350641062D0627062A
0637063106270632
0639063106350647
063906A90633
063906440645
063906440645064A
0639064406480645200C063406310642064A
06390645064400BB
063906480636060C
063A064406280647
064106310647064606AF
0642063106270631
06420648064A
06A90627063106470627064A
06A906270631064A
06A90627064506440627064B
06A90627064606480646
06A9062A06270628
06A90631062F0646062F
06A9064506280631064A062C
06A9064806340634
06A90647
06AF
06AF06310641062A0647
06AF06310645064A
06440646062F0646
064506270646062F
0645062C06440633
0645062D064206510642
0645062E062A06270631
0645062F063106330647
0645063306270639062F
064506340631064806370647
06450635064506510645
06450642062706440627062A
06450646
06450646062A06340631
06450646062A06420644
064506480631062F
064506470645
06450647064506270646
0645064A
0645064A200C062F0647062F060C
0646062706450647
064606280648062F060C
064606330628062A
0646063406270646
064606380631
064606450627064A0646062F0647
064606480634062A0647
064606470636062A
0646064A0632
0648
0648067E0646062C
06480632064A0631
06480644064A
0648064A
0648064A06980647
064706500646064A064606AF
0647063106860646062F
06470645
0647064506270646
0647064506330631
06470645063306310634
064706450647
0647064606AF06270645064A
0647064A0626062A
064A062706310634062706370631
064A06A9
064A06A9062F064A06AF0631
064A06A9064A
DROP TABLE t1;
mysql-test/r/func_set.result
View file @
a8b38dd7
...
@@ -64,3 +64,6 @@ find_in_set('a',binary 'A,B,C')
...
@@ -64,3 +64,6 @@ find_in_set('a',binary 'A,B,C')
select find_in_set(binary 'a', 'A,B,C');
select find_in_set(binary 'a', 'A,B,C');
find_in_set(binary 'a', 'A,B,C')
find_in_set(binary 'a', 'A,B,C')
0
0
select find_in_set('1','3,1,');
find_in_set('1','3,1,')
2
mysql-test/r/order_by.result
View file @
a8b38dd7
...
@@ -723,3 +723,16 @@ col2 col col
...
@@ -723,3 +723,16 @@ col2 col col
2 2 2
2 2 2
1 3 3
1 3 3
drop table t1, t2;
drop table t1, t2;
create table t1 (a char(25));
insert into t1 set a = repeat('x', 20);
insert into t1 set a = concat(repeat('x', 19), 'z');
insert into t1 set a = concat(repeat('x', 19), 'ab');
insert into t1 set a = concat(repeat('x', 19), 'aa');
set max_sort_length=20;
select a from t1 order by a;
a
xxxxxxxxxxxxxxxxxxxab
xxxxxxxxxxxxxxxxxxxaa
xxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxz
drop table t1;
mysql-test/t/ctype_uca.test
View file @
a8b38dd7
...
@@ -217,3 +217,194 @@ INSERT INTO t1 VALUES (CONVERT(_ucs2 0x039C03C903B4 USING utf8));
...
@@ -217,3 +217,194 @@ INSERT INTO t1 VALUES (CONVERT(_ucs2 0x039C03C903B4 USING utf8));
SELECT
*
FROM
t1
WHERE
c
LIKE
CONVERT
(
_ucs2
0x039C0025
USING
utf8
)
SELECT
*
FROM
t1
WHERE
c
LIKE
CONVERT
(
_ucs2
0x039C0025
USING
utf8
)
COLLATE
utf8_unicode_ci
ORDER
BY
c
;
COLLATE
utf8_unicode_ci
ORDER
BY
c
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
CREATE
TABLE
t1
(
col1
CHAR
(
32
)
CHARACTER
SET
utf8
NOT
NULL
);
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0041004100410627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0041004100410628
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0041004100410647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0041004100410648
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0633064A0651062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062D06330646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0642064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06320627062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062806310627064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064706450647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F062706460634062C0648064A06270646064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A90647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A06270631064A062E
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062706460642064406270628
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A0631062706460650
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627062F064806270631062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280631062706480646200C06310627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062E064806270646062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0648
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A062D062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0623062B064A0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06220646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0642063106270631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06AF06310641062A0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270646062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0634062E0635064A0651062A064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628062706310632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270633062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063906A90633
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270648060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062D062F0648062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628064A0633062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0648067E0646062C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06330627064406AF064A060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063306270644
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606450627064A0646062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A06280631064A0632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645062C06440633
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280648062F060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628064A0646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06350641062D0627062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A0646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A9062A06270628
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x068606340645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062E06480631062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0686064706310647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06420648064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450635064506510645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06310627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0646063406270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645064A200C062F0647062F060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0647063106860646062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06390645064400BB
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A9064806340634
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064706500646064A064606AF
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627062D063306270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064A062706310634062706370631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450646062A06340631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0634062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F0633062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A064806270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0647064506270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064806510644
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0634062E064A0635
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F0627062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A064106270648062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062D06270644062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A064106A906510631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063A064406280647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F06270631062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064A06A9064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063106470628063106270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606470636062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064506340631064806370647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A063106270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0646064A0632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064A06A9
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645062D064206510642
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0637063106270632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064106310647064606AF
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0645062F06510646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A063106270646064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280648062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A90627063106470627064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270648
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0639063106350647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064506480631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0633064A06270633064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064A063106270646060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062D064806320647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063906440645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F062706460634
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450642062706440627062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F064A06AF0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0648064A06980647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0646062706450647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064506480631062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628062D062B
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0628063106310633064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606480634062A0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A064606470627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0622064606860647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F064806310647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064206270645062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x067E0631062F062706320645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0698062706460648064A0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0648064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F06390648062A0650
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063306500631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F0646064A0633064F0646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063106270633
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0647064A0626062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0639064406480645200C063406310642064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280639062F0627064B
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645062F063106330647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062206410631064A06420627064A064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F06270646063406AF06270647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06440646062F0646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x067E064A06480633062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0647064606AF06270645064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x067E0633
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0622063A06270632
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062C064606AF
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062C064706270646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F064806510645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063406470631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A9064506280631064A062C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450646062A06420644
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A90631062F0646062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06470645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06310641062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06220646062C0627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064506270646062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0627
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062706A9062A06280631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606380631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F06480644062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F06480628062706310647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606330628062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645063306270639062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0634062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06480632064A0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0645062E062A06270631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06330641064A0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627064606AF0644064A0633
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0642064A200C06320627062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280627063206AF0634062A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0647064506330631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06220644064506270646064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06270634
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06220645062F0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A906270631064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x067E0631062F0627062E062A0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063906440645064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x0627062F0628064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062D062F0651
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064606280648062F060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06480644064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x063906480636060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06340627064A062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064506470645
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062A0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06220646060C
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06470645063306310634
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A90627064606480646
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062E0627064606480627062F06AF064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06AF06310645064A
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280648062C0648062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062206480631062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F0648
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06A90627064506440627064B
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x064A06A9062F064A06AF0631
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06AF
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x062F064406280633062A0647
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06280648062F0646062F
USING
utf8
));
INSERT
INTO
t1
VALUES
(
CONVERT
(
_ucs2
0x06450647064506270646
USING
utf8
));
SELECT
HEX
(
CONVERT
(
col1
USING
ucs2
))
FROM
t1
ORDER
BY
col1
COLLATE
utf8_persian_ci
,
col1
COLLATE
utf8_bin
;
DROP
TABLE
t1
;
mysql-test/t/func_set.test
View file @
a8b38dd7
...
@@ -47,3 +47,8 @@ select find_in_set(binary 'a',binary 'A,B,C');
...
@@ -47,3 +47,8 @@ select find_in_set(binary 'a',binary 'A,B,C');
select
find_in_set
(
'a'
,
binary
'A,B,C'
);
select
find_in_set
(
'a'
,
binary
'A,B,C'
);
select
find_in_set
(
binary
'a'
,
'A,B,C'
);
select
find_in_set
(
binary
'a'
,
'A,B,C'
);
#
# Bug5513:FIND_IN_SET fails if set ends with a comma
#
select
find_in_set
(
'1'
,
'3,1,'
);
mysql-test/t/order_by.test
View file @
a8b38dd7
...
@@ -486,3 +486,16 @@ select t2.col2 as col, t2.col from t2 order by t2.col;
...
@@ -486,3 +486,16 @@ select t2.col2 as col, t2.col from t2 order by t2.col;
select
t2
.
col2
,
t2
.
col
,
t2
.
col
from
t2
order
by
t2
.
col
;
select
t2
.
col2
,
t2
.
col
,
t2
.
col
from
t2
order
by
t2
.
col
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
#
# Bug #5428: a problem with small max_sort_length value
#
create
table
t1
(
a
char
(
25
));
insert
into
t1
set
a
=
repeat
(
'x'
,
20
);
insert
into
t1
set
a
=
concat
(
repeat
(
'x'
,
19
),
'z'
);
insert
into
t1
set
a
=
concat
(
repeat
(
'x'
,
19
),
'ab'
);
insert
into
t1
set
a
=
concat
(
repeat
(
'x'
,
19
),
'aa'
);
set
max_sort_length
=
20
;
select
a
from
t1
order
by
a
;
drop
table
t1
;
mysys/charset-def.c
View file @
a8b38dd7
...
@@ -39,6 +39,7 @@ extern CHARSET_INFO my_charset_ucs2_lithuanian_uca_ci;
...
@@ -39,6 +39,7 @@ extern CHARSET_INFO my_charset_ucs2_lithuanian_uca_ci;
extern
CHARSET_INFO
my_charset_ucs2_slovak_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_slovak_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_spanish2_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_spanish2_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_roman_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_roman_uca_ci
;
extern
CHARSET_INFO
my_charset_ucs2_persian_uca_ci
;
#endif
#endif
#ifdef HAVE_CHARSET_utf8
#ifdef HAVE_CHARSET_utf8
...
@@ -58,6 +59,7 @@ extern CHARSET_INFO my_charset_utf8_lithuanian_uca_ci;
...
@@ -58,6 +59,7 @@ extern CHARSET_INFO my_charset_utf8_lithuanian_uca_ci;
extern
CHARSET_INFO
my_charset_utf8_slovak_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_slovak_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_spanish2_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_spanish2_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_roman_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_roman_uca_ci
;
extern
CHARSET_INFO
my_charset_utf8_persian_uca_ci
;
#endif
#endif
my_bool
init_compiled_charsets
(
myf
flags
__attribute__
((
unused
)))
my_bool
init_compiled_charsets
(
myf
flags
__attribute__
((
unused
)))
...
@@ -127,6 +129,7 @@ my_bool init_compiled_charsets(myf flags __attribute__((unused)))
...
@@ -127,6 +129,7 @@ my_bool init_compiled_charsets(myf flags __attribute__((unused)))
add_compiled_collation
(
&
my_charset_ucs2_slovak_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_slovak_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_spanish2_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_spanish2_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_roman_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_roman_uca_ci
);
add_compiled_collation
(
&
my_charset_ucs2_persian_uca_ci
);
#endif
#endif
#ifdef HAVE_CHARSET_ujis
#ifdef HAVE_CHARSET_ujis
...
@@ -153,6 +156,7 @@ my_bool init_compiled_charsets(myf flags __attribute__((unused)))
...
@@ -153,6 +156,7 @@ my_bool init_compiled_charsets(myf flags __attribute__((unused)))
add_compiled_collation
(
&
my_charset_utf8_slovak_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_slovak_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_spanish2_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_spanish2_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_roman_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_roman_uca_ci
);
add_compiled_collation
(
&
my_charset_utf8_persian_uca_ci
);
#endif
#endif
/* Copy compiled charsets */
/* Copy compiled charsets */
...
...
sql/examples/ha_tina.h
View file @
a8b38dd7
...
@@ -90,6 +90,12 @@ class ha_tina: public handler
...
@@ -90,6 +90,12 @@ class ha_tina: public handler
/* The next method will never be called */
/* The next method will never be called */
virtual
double
read_time
(
ha_rows
rows
)
{
DBUG_ASSERT
(
0
);
return
((
double
)
rows
/
20.0
+
1
);
}
virtual
double
read_time
(
ha_rows
rows
)
{
DBUG_ASSERT
(
0
);
return
((
double
)
rows
/
20.0
+
1
);
}
virtual
bool
fast_key_read
()
{
return
1
;}
virtual
bool
fast_key_read
()
{
return
1
;}
/*
TODO: return actual upper bound of number of records in the table.
(e.g. save number of records seen on full table scan and/or use file size
as upper bound)
*/
ha_rows
estimate_rows_upper_bound
()
{
return
HA_POS_ERROR
;
}
int
open
(
const
char
*
name
,
int
mode
,
uint
test_if_locked
);
int
open
(
const
char
*
name
,
int
mode
,
uint
test_if_locked
);
int
close
(
void
);
int
close
(
void
);
...
...
sql/filesort.cc
View file @
a8b38dd7
...
@@ -169,7 +169,13 @@ ha_rows filesort(THD *thd, TABLE *table, SORT_FIELD *sortorder, uint s_length,
...
@@ -169,7 +169,13 @@ ha_rows filesort(THD *thd, TABLE *table, SORT_FIELD *sortorder, uint s_length,
else
else
#endif
#endif
{
{
records
=
table
->
file
->
estimate_number_of_rows
();
records
=
table
->
file
->
estimate_rows_upper_bound
();
/*
If number of records is not known, use as much of sort buffer
as possible.
*/
if
(
records
==
HA_POS_ERROR
)
records
--
;
// we use 'records+1' below.
selected_records_file
=
0
;
selected_records_file
=
0
;
}
}
...
@@ -315,7 +321,7 @@ static char **make_char_array(register uint fields, uint length, myf my_flag)
...
@@ -315,7 +321,7 @@ static char **make_char_array(register uint fields, uint length, myf my_flag)
}
/* make_char_array */
}
/* make_char_array */
/* Read all
buffer pointers into memory */
/* Read 'count' number of
buffer pointers into memory */
static
BUFFPEK
*
read_buffpek_from_file
(
IO_CACHE
*
buffpek_pointers
,
uint
count
)
static
BUFFPEK
*
read_buffpek_from_file
(
IO_CACHE
*
buffpek_pointers
,
uint
count
)
{
{
...
@@ -336,8 +342,40 @@ static BUFFPEK *read_buffpek_from_file(IO_CACHE *buffpek_pointers, uint count)
...
@@ -336,8 +342,40 @@ static BUFFPEK *read_buffpek_from_file(IO_CACHE *buffpek_pointers, uint count)
}
}
/*
/* Search after sort_keys and place them in a temp. file */
Search after sort_keys and write them into tempfile.
SYNOPSIS
find_all_keys()
param Sorting parameter
select Use this to get source data
sort_keys Array of pointers to sort key + addon buffers.
buffpek_pointers File to write BUFFPEKs describing sorted segments
in tempfile.
tempfile File to write sorted sequences of sortkeys to.
indexfile If !NULL, use it for source data (contains rowids)
NOTE
Basic idea:
while (get_next_sortkey())
{
if (no free space in sort_keys buffers)
{
sort sort_keys buffer;
dump sorted sequence to 'tempfile';
dump BUFFPEK describing sequence location into 'buffpek_pointers';
}
put sort key into 'sort_keys';
}
if (sort_keys has some elements && dumped at least once)
sort-dump-dump as above;
else
don't sort, leave sort_keys array to be sorted by caller.
All produced sequences are guaranteed to be non-empty.
RETURN
Number of records written on success.
HA_POS_ERROR on error.
*/
static
ha_rows
find_all_keys
(
SORTPARAM
*
param
,
SQL_SELECT
*
select
,
static
ha_rows
find_all_keys
(
SORTPARAM
*
param
,
SQL_SELECT
*
select
,
uchar
**
sort_keys
,
uchar
**
sort_keys
,
...
@@ -452,7 +490,25 @@ static ha_rows find_all_keys(SORTPARAM *param, SQL_SELECT *select,
...
@@ -452,7 +490,25 @@ static ha_rows find_all_keys(SORTPARAM *param, SQL_SELECT *select,
}
/* find_all_keys */
}
/* find_all_keys */
/* Skriver en buffert med nycklar till filen */
/*
Sort the buffer and write:
1) the sorted sequence to tempfile
2) a BUFFPEK describing the sorted sequence position to buffpek_pointers
(was: Skriver en buffert med nycklar till filen)
SYNOPSIS
write_keys()
param Sort parameters
sort_keys Array of pointers to keys to sort
count Number of elements in sort_keys array
buffpek_pointers One 'BUFFPEK' struct will be written into this file.
The BUFFPEK::{file_pos, count} will indicate where
the sorted data was stored.
tempfile The sorted sequence will be written into this file.
RETURN
0 OK
1 Error
*/
static
int
static
int
write_keys
(
SORTPARAM
*
param
,
register
uchar
**
sort_keys
,
uint
count
,
write_keys
(
SORTPARAM
*
param
,
register
uchar
**
sort_keys
,
uint
count
,
...
@@ -784,7 +840,21 @@ uint read_to_buffer(IO_CACHE *fromfile, BUFFPEK *buffpek,
...
@@ -784,7 +840,21 @@ uint read_to_buffer(IO_CACHE *fromfile, BUFFPEK *buffpek,
/*
/*
Merge buffers to one buffer
Merge buffers to one buffer
SYNOPSIS
merge_buffers()
param Sort parameter
from_file File with source data (BUFFPEKs point to this file)
to_file File to write the sorted result data.
sort_buffer Buffer for data to store up to MERGEBUFF2 sort keys.
lastbuff OUT Store here BUFFPEK describing data written to to_file
Fb First element in source BUFFPEKs array
Tb Last element in source BUFFPEKs array
flag
RETURN
0 - OK
other - error
*/
*/
int
merge_buffers
(
SORTPARAM
*
param
,
IO_CACHE
*
from_file
,
int
merge_buffers
(
SORTPARAM
*
param
,
IO_CACHE
*
from_file
,
...
@@ -822,6 +892,9 @@ int merge_buffers(SORTPARAM *param, IO_CACHE *from_file,
...
@@ -822,6 +892,9 @@ int merge_buffers(SORTPARAM *param, IO_CACHE *from_file,
strpos
=
(
uchar
*
)
sort_buffer
;
strpos
=
(
uchar
*
)
sort_buffer
;
org_max_rows
=
max_rows
=
param
->
max_rows
;
org_max_rows
=
max_rows
=
param
->
max_rows
;
/* The following will fire if there is not enough space in sort_buffer */
DBUG_ASSERT
(
maxcount
!=
0
);
if
(
init_queue
(
&
queue
,
(
uint
)
(
Tb
-
Fb
)
+
1
,
offsetof
(
BUFFPEK
,
key
),
0
,
if
(
init_queue
(
&
queue
,
(
uint
)
(
Tb
-
Fb
)
+
1
,
offsetof
(
BUFFPEK
,
key
),
0
,
(
queue_compare
)
(
cmp
=
get_ptr_compare
(
sort_length
)),
(
queue_compare
)
(
cmp
=
get_ptr_compare
(
sort_length
)),
(
void
*
)
&
sort_length
))
(
void
*
)
&
sort_length
))
...
...
sql/ha_berkeley.cc
View file @
a8b38dd7
...
@@ -25,7 +25,7 @@
...
@@ -25,7 +25,7 @@
We will need an updated Berkeley DB version for this.
We will need an updated Berkeley DB version for this.
- Killing threads that has got a 'deadlock'
- Killing threads that has got a 'deadlock'
- SHOW TABLE STATUS should give more information about the table.
- SHOW TABLE STATUS should give more information about the table.
- Get a more accurate count of the number of rows (estimate_
number_of_rows
()).
- Get a more accurate count of the number of rows (estimate_
rows_upper_bound
()).
We could store the found number of rows when the table is scanned and
We could store the found number of rows when the table is scanned and
then increment the counter for each attempted write.
then increment the counter for each attempted write.
- We will need to extend the manager thread to makes checkpoints at
- We will need to extend the manager thread to makes checkpoints at
...
@@ -63,7 +63,7 @@
...
@@ -63,7 +63,7 @@
#define HA_BERKELEY_ROWS_IN_TABLE 10000
/* to get optimization right */
#define HA_BERKELEY_ROWS_IN_TABLE 10000
/* to get optimization right */
#define HA_BERKELEY_RANGE_COUNT 100
#define HA_BERKELEY_RANGE_COUNT 100
#define HA_BERKELEY_MAX_ROWS 10000000
/* Max rows in table */
#define HA_BERKELEY_MAX_ROWS 10000000
/* Max rows in table */
/* extra rows for estimate_
number_of_rows
() */
/* extra rows for estimate_
rows_upper_bound
() */
#define HA_BERKELEY_EXTRA_ROWS 100
#define HA_BERKELEY_EXTRA_ROWS 100
/* Bits for share->status */
/* Bits for share->status */
...
@@ -2556,7 +2556,7 @@ end:
...
@@ -2556,7 +2556,7 @@ end:
Used when sorting to allocate buffers and by the optimizer.
Used when sorting to allocate buffers and by the optimizer.
*/
*/
ha_rows
ha_berkeley
::
estimate_
number_of_rows
()
ha_rows
ha_berkeley
::
estimate_
rows_upper_bound
()
{
{
return
share
->
rows
+
HA_BERKELEY_EXTRA_ROWS
;
return
share
->
rows
+
HA_BERKELEY_EXTRA_ROWS
;
}
}
...
...
sql/ha_berkeley.h
View file @
a8b38dd7
...
@@ -100,7 +100,7 @@ class ha_berkeley: public handler
...
@@ -100,7 +100,7 @@ class ha_berkeley: public handler
ulong
table_flags
(
void
)
const
{
return
int_table_flags
;
}
ulong
table_flags
(
void
)
const
{
return
int_table_flags
;
}
uint
max_supported_keys
()
const
{
return
MAX_KEY
-
1
;
}
uint
max_supported_keys
()
const
{
return
MAX_KEY
-
1
;
}
uint
extra_rec_buf_length
()
{
return
BDB_HIDDEN_PRIMARY_KEY_LENGTH
;
}
uint
extra_rec_buf_length
()
{
return
BDB_HIDDEN_PRIMARY_KEY_LENGTH
;
}
ha_rows
estimate_
number_of_rows
();
ha_rows
estimate_
rows_upper_bound
();
const
key_map
*
keys_to_use_for_scanning
()
{
return
&
key_map_full
;
}
const
key_map
*
keys_to_use_for_scanning
()
{
return
&
key_map_full
;
}
bool
has_transactions
()
{
return
1
;}
bool
has_transactions
()
{
return
1
;}
...
...
sql/ha_innodb.cc
View file @
a8b38dd7
...
@@ -4115,7 +4115,7 @@ Gives an UPPER BOUND to the number of rows in a table. This is used in
...
@@ -4115,7 +4115,7 @@ Gives an UPPER BOUND to the number of rows in a table. This is used in
filesort.cc. */
filesort.cc. */
ha_rows
ha_rows
ha_innobase
::
estimate_
number_of_rows
(
void
)
ha_innobase
::
estimate_
rows_upper_bound
(
void
)
/*======================================*/
/*======================================*/
/* out: upper bound of rows */
/* out: upper bound of rows */
{
{
...
@@ -4124,7 +4124,7 @@ ha_innobase::estimate_number_of_rows(void)
...
@@ -4124,7 +4124,7 @@ ha_innobase::estimate_number_of_rows(void)
ulonglong
estimate
;
ulonglong
estimate
;
ulonglong
local_data_file_length
;
ulonglong
local_data_file_length
;
DBUG_ENTER
(
"estimate_
number_of_rows
"
);
DBUG_ENTER
(
"estimate_
rows_upper_bound
"
);
/* We do not know if MySQL can call this function before calling
/* We do not know if MySQL can call this function before calling
external_lock(). To be safe, update the thd of the current table
external_lock(). To be safe, update the thd of the current table
...
@@ -4204,7 +4204,7 @@ ha_innobase::read_time(
...
@@ -4204,7 +4204,7 @@ ha_innobase::read_time(
time_for_scan
=
scan_time
();
time_for_scan
=
scan_time
();
if
((
total_rows
=
estimate_
number_of_rows
())
<
rows
)
if
((
total_rows
=
estimate_
rows_upper_bound
())
<
rows
)
return
time_for_scan
;
return
time_for_scan
;
return
(
ranges
+
(
double
)
rows
/
(
double
)
total_rows
*
time_for_scan
);
return
(
ranges
+
(
double
)
rows
/
(
double
)
total_rows
*
time_for_scan
);
...
...
sql/ha_innodb.h
View file @
a8b38dd7
...
@@ -150,7 +150,7 @@ class ha_innobase: public handler
...
@@ -150,7 +150,7 @@ class ha_innobase: public handler
void
position
(
byte
*
record
);
void
position
(
byte
*
record
);
ha_rows
records_in_range
(
uint
inx
,
key_range
*
min_key
,
key_range
*
max_key
);
ha_rows
records_in_range
(
uint
inx
,
key_range
*
min_key
,
key_range
*
max_key
);
ha_rows
estimate_
number_of_rows
();
ha_rows
estimate_
rows_upper_bound
();
int
create
(
const
char
*
name
,
register
TABLE
*
form
,
int
create
(
const
char
*
name
,
register
TABLE
*
form
,
HA_CREATE_INFO
*
create_info
);
HA_CREATE_INFO
*
create_info
);
...
...
sql/handler.h
View file @
a8b38dd7
...
@@ -300,7 +300,15 @@ public:
...
@@ -300,7 +300,15 @@ public:
virtual
const
key_map
*
keys_to_use_for_scanning
()
{
return
&
key_map_empty
;
}
virtual
const
key_map
*
keys_to_use_for_scanning
()
{
return
&
key_map_empty
;
}
virtual
bool
has_transactions
(){
return
0
;}
virtual
bool
has_transactions
(){
return
0
;}
virtual
uint
extra_rec_buf_length
()
{
return
0
;
}
virtual
uint
extra_rec_buf_length
()
{
return
0
;
}
virtual
ha_rows
estimate_number_of_rows
()
{
return
records
+
EXTRA_RECORDS
;
}
/*
Return upper bound of current number of records in the table
(max. of how many records one will retrieve when doing a full table scan)
If upper bound is not known, HA_POS_ERROR should be returned as a max
possible upper bound.
*/
virtual
ha_rows
estimate_rows_upper_bound
()
{
return
records
+
EXTRA_RECORDS
;
}
virtual
const
char
*
index_type
(
uint
key_number
)
{
DBUG_ASSERT
(
0
);
return
""
;}
virtual
const
char
*
index_type
(
uint
key_number
)
{
DBUG_ASSERT
(
0
);
return
""
;}
...
...
sql/item_func.cc
View file @
a8b38dd7
...
@@ -1455,10 +1455,11 @@ longlong Item_func_find_in_set::val_int()
...
@@ -1455,10 +1455,11 @@ longlong Item_func_find_in_set::val_int()
{
{
const
char
*
substr_end
=
str_end
+
symbol_len
;
const
char
*
substr_end
=
str_end
+
symbol_len
;
bool
is_last_item
=
(
substr_end
==
real_end
);
bool
is_last_item
=
(
substr_end
==
real_end
);
if
(
wc
==
(
my_wc_t
)
separator
||
is_last_item
)
bool
is_separator
=
(
wc
==
(
my_wc_t
)
separator
);
if
(
is_separator
||
is_last_item
)
{
{
position
++
;
position
++
;
if
(
is_last_item
)
if
(
is_last_item
&&
!
is_separator
)
str_end
=
substr_end
;
str_end
=
substr_end
;
if
(
!
my_strnncoll
(
cs
,
(
const
uchar
*
)
str_begin
,
if
(
!
my_strnncoll
(
cs
,
(
const
uchar
*
)
str_begin
,
str_end
-
str_begin
,
str_end
-
str_begin
,
...
...
strings/ctype-uca.c
View file @
a8b38dd7
...
@@ -6657,6 +6657,42 @@ static const char roman[]= /* i.e. Classical Latin */
...
@@ -6657,6 +6657,42 @@ static const char roman[]= /* i.e. Classical Latin */
"& I << j <<< J "
"& I << j <<< J "
"& V << u <<< U "
;
"& V << u <<< U "
;
/*
Persian collation support was provided by
Jody McIntyre <mysql@modernduck.com>
To: internals@lists.mysql.com
Subject: Persian UTF8 collation support
Date: 17.08.2004
Contraction is not implemented. Some implementations do perform
contraction but others do not, and it is able to sort all my test
strings correctly.
Jody.
*/
static
const
char
persian
[]
=
"&
\\
u066D <
\\
u064E <
\\
uFE76 <
\\
uFE77 <
\\
u0650 <
\\
uFE7A <
\\
uFE7B"
" <
\\
u064F <
\\
uFE78 <
\\
uFE79 <
\\
u064B <
\\
uFE70 <
\\
uFE71"
" <
\\
u064D <
\\
uFE74 <
\\
u064C <
\\
uFE72"
"&
\\
uFE7F <
\\
u0653 <
\\
u0654 <
\\
u0655 <
\\
u0670"
"&
\\
u0669 <
\\
u0622 <
\\
u0627 <
\\
u0671 <
\\
u0621 <
\\
u0623 <
\\
u0625"
" <
\\
u0624 <
\\
u0626"
"&
\\
u0642 <
\\
u06A9 <
\\
u0643"
"&
\\
u0648 <
\\
u0647 <
\\
u0629 <
\\
u06C0 <
\\
u06CC <
\\
u0649 <
\\
u064A"
"&
\\
uFE80 <
\\
uFE81 <
\\
uFE82 <
\\
uFE8D <
\\
uFE8E <
\\
uFB50 <
\\
uFB51"
" <
\\
uFE80 <
\\
uFE83 <
\\
uFE84 <
\\
uFE87 <
\\
uFE88 <
\\
uFE85"
" <
\\
uFE86 <
\\
u0689 <
\\
u068A"
"&
\\
uFEAE <
\\
uFDFC"
"&
\\
uFED8 <
\\
uFB8E <
\\
uFB8F <
\\
uFB90 <
\\
uFB91 <
\\
uFED9 <
\\
uFEDA"
" <
\\
uFEDB <
\\
uFEDC"
"&
\\
uFEEE <
\\
uFEE9 <
\\
uFEEA <
\\
uFEEB <
\\
uFEEC <
\\
uFE93 <
\\
uFE94"
" <
\\
uFBA4 <
\\
uFBA5 <
\\
uFBFC <
\\
uFBFD <
\\
uFBFE <
\\
uFBFF"
" <
\\
uFEEF <
\\
uFEF0 <
\\
uFEF1 <
\\
uFEF2 <
\\
uFEF3 <
\\
uFEF4"
" <
\\
uFEF5 <
\\
uFEF6 <
\\
uFEF7 <
\\
uFEF8 <
\\
uFEF9 <
\\
uFEFA"
" <
\\
uFEFB <
\\
uFEFC"
;
/*
/*
Unicode Collation Algorithm:
Unicode Collation Algorithm:
Collation element (weight) scanner,
Collation element (weight) scanner,
...
@@ -7671,7 +7707,7 @@ static int my_coll_rule_parse(MY_COLL_RULE *rule, size_t mitems,
...
@@ -7671,7 +7707,7 @@ static int my_coll_rule_parse(MY_COLL_RULE *rule, size_t mitems,
return
(
size_t
)
nitems
;
return
(
size_t
)
nitems
;
}
}
#define MY_MAX_COLL_RULE
64
#define MY_MAX_COLL_RULE
128
/*
/*
This function copies an UCS2 collation from
This function copies an UCS2 collation from
...
@@ -8360,6 +8396,35 @@ CHARSET_INFO my_charset_ucs2_roman_uca_ci=
...
@@ -8360,6 +8396,35 @@ CHARSET_INFO my_charset_ucs2_roman_uca_ci=
&
my_collation_ucs2_uca_handler
&
my_collation_ucs2_uca_handler
};
};
CHARSET_INFO
my_charset_ucs2_persian_uca_ci
=
{
144
,
0
,
0
,
/* number */
MY_CS_COMPILED
|
MY_CS_STRNXFRM
|
MY_CS_UNICODE
,
"ucs2"
,
/* cs name */
"ucs2_persian_ci"
,
/* name */
""
,
/* comment */
persian
,
/* tailoring */
NULL
,
/* ctype */
NULL
,
/* to_lower */
NULL
,
/* to_upper */
NULL
,
/* sort_order */
NULL
,
/* contractions */
NULL
,
/* sort_order_big*/
NULL
,
/* tab_to_uni */
NULL
,
/* tab_from_uni */
NULL
,
/* state_map */
NULL
,
/* ident_map */
8
,
/* strxfrm_multiply */
2
,
/* mbminlen */
2
,
/* mbmaxlen */
9
,
/* min_sort_char */
0xFFFF
,
/* max_sort_char */
&
my_charset_ucs2_handler
,
&
my_collation_ucs2_uca_handler
};
#endif
#endif
...
@@ -8838,4 +8903,32 @@ CHARSET_INFO my_charset_utf8_roman_uca_ci=
...
@@ -8838,4 +8903,32 @@ CHARSET_INFO my_charset_utf8_roman_uca_ci=
&
my_charset_utf8_handler
,
&
my_charset_utf8_handler
,
&
my_collation_any_uca_handler
&
my_collation_any_uca_handler
};
};
CHARSET_INFO
my_charset_utf8_persian_uca_ci
=
{
208
,
0
,
0
,
/* number */
MY_CS_COMPILED
|
MY_CS_STRNXFRM
|
MY_CS_UNICODE
,
"utf8"
,
/* cs name */
"utf8_persian_ci"
,
/* name */
""
,
/* comment */
persian
,
/* tailoring */
ctype_utf8
,
/* ctype */
NULL
,
/* to_lower */
NULL
,
/* to_upper */
NULL
,
/* sort_order */
NULL
,
/* contractions */
NULL
,
/* sort_order_big*/
NULL
,
/* tab_to_uni */
NULL
,
/* tab_from_uni */
NULL
,
/* state_map */
NULL
,
/* ident_map */
8
,
/* strxfrm_multiply */
1
,
/* mbminlen */
2
,
/* mbmaxlen */
9
,
/* min_sort_char */
0xFFFF
,
/* max_sort_char */
&
my_charset_utf8_handler
,
&
my_collation_any_uca_handler
};
#endif
#endif
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