mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
dd2a44c497
internal charset to one associated with currently being handled query. To note such a query can come from interactive client either. There was a discussion within replication team and Monty who's suggestion won. It avoids straightforward parsing of all `set' queries that could affect client side character set. According to the idea, mysql client does not parse `set' queries but rather cares of `charset new_cs_name' command. This command is generated by mysqlbinlog in form of exclaiming comment (Lars' suggestion) so that enlightened clients like `mysql' knows what to do with it. Interactive human can switch between many multi-byte charsets during the session providing the command explicitly. To note that setting new internal mysql's charset does not trigger sending any `SET' sql statement to the server.
56 lines
1.9 KiB
Text
56 lines
1.9 KiB
Text
#
|
|
# Testing the MySQL command line client(mysql)
|
|
#
|
|
|
|
--disable_warnings
|
|
drop table if exists t1;
|
|
--enable_warnings
|
|
|
|
#
|
|
# Test the "delimiter" functionality
|
|
# Bug#9879
|
|
#
|
|
create table t1(a int);
|
|
insert into t1 values(1);
|
|
|
|
# Test delimiters
|
|
--exec $MYSQL test 2>&1 < "./t/mysql_delimiter.sql"
|
|
|
|
--disable_query_log
|
|
# Test delimiter : supplied on the command line
|
|
select "Test delimiter : from command line" as " ";
|
|
--exec $MYSQL test --delimiter=":" -e "select * from t1:"
|
|
# Test delimiter :; supplied on the command line
|
|
select "Test delimiter :; from command line" as " ";
|
|
--exec $MYSQL test --delimiter=":;" -e "select * from t1:;"
|
|
# Test 'go' command (vertical output) \G
|
|
select "Test 'go' command(vertical output) \G" as " ";
|
|
--exec $MYSQL test -e "select * from t1\G"
|
|
# Test 'go' command \g
|
|
select "Test 'go' command \g" as " ";
|
|
--exec $MYSQL test -e "select * from t1\g"
|
|
--enable_query_log
|
|
drop table t1;
|
|
|
|
#
|
|
# BUG9998 - MySQL client hangs on USE "database"
|
|
#
|
|
create table t1(a int);
|
|
lock tables t1 write;
|
|
--exec $MYSQL -e "use test; select database();"
|
|
unlock tables;
|
|
drop table t1;
|
|
|
|
#
|
|
# BUG#16217 - MySQL client misinterpretes multi-byte char as escape `\'
|
|
#
|
|
|
|
# new command \C or charset
|
|
--exec $MYSQL --default-character-set=utf8 test -e "\C cp932 \g"
|
|
--exec $MYSQL --default-character-set=cp932 test -e "charset utf8;"
|
|
|
|
# its usage to switch internally in mysql to requested charset
|
|
--exec $MYSQL --default-character-set=utf8 test -e "charset cp932; set @@session.character_set_client= cp932; select 'ƒ\'; create table t1 (c_cp932 TEXT CHARACTER SET cp932); insert into t1 values('ƒ\'); select * from t1; drop table t1;"
|
|
--exec $MYSQL --default-character-set=utf8 test -e "charset cp932; set character_set_client= cp932; select 'ƒ\'"
|
|
--exec $MYSQL --default-character-set=utf8 test -e "/*charset cp932 */; set character_set_client= cp932; select 'ƒ\'"
|
|
--exec $MYSQL --default-character-set=utf8 test -e "/*!\C cp932 */; set character_set_client= cp932; select 'ƒ\'"
|