mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Manual merge from mysql-next-mr.
Conflicts: - sql/sql_base.cc
This commit is contained in:
@ -1658,3 +1658,14 @@ INSERT INTO t1 (col1, col2) VALUES (1, "value");
|
||||
REPAIR TABLE t1;
|
||||
DROP TABLE t1;
|
||||
remove_file $MYSQLD_DATADIR/test/t1.ARM;
|
||||
|
||||
--echo #
|
||||
--echo # BUG#48757 - missing .ARZ file causes server crash
|
||||
--echo #
|
||||
CREATE TABLE t1(a INT) ENGINE=ARCHIVE;
|
||||
FLUSH TABLE t1;
|
||||
--remove_file $MYSQLD_DATADIR/test/t1.ARZ
|
||||
--error ER_FILE_NOT_FOUND
|
||||
SELECT * FROM t1;
|
||||
--error ER_BAD_TABLE_ERROR
|
||||
DROP TABLE t1;
|
||||
|
@ -327,3 +327,38 @@ drop table t1;
|
||||
create table t1 select -9223372036854775809 bi;
|
||||
describe t1;
|
||||
drop table t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #45360: wrong results
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 (id INT AUTO_INCREMENT PRIMARY KEY,
|
||||
a BIGINT(20) UNSIGNED,
|
||||
b VARCHAR(20));
|
||||
|
||||
INSERT INTO t1 (a) VALUES
|
||||
(0),
|
||||
(CAST(0x7FFFFFFFFFFFFFFF AS UNSIGNED)),
|
||||
(CAST(0x8000000000000000 AS UNSIGNED)),
|
||||
(CAST(0xFFFFFFFFFFFFFFFF AS UNSIGNED));
|
||||
|
||||
UPDATE t1 SET b = a;
|
||||
|
||||
let $n = `SELECT MAX(id) FROM t1`;
|
||||
while($n) {
|
||||
let $x = `SELECT a FROM t1 WHERE id = $n`;
|
||||
dec $n;
|
||||
let $hex = `SELECT HEX($x)`;
|
||||
echo # $hex;
|
||||
|
||||
--disable_result_log
|
||||
eval EXPLAIN EXTENDED SELECT 1 FROM t1 WHERE a = $x AND TRIM(a) = b;
|
||||
--enable_result_log
|
||||
SHOW WARNINGS;
|
||||
}
|
||||
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo # End of 5.1 tests
|
||||
|
||||
|
||||
|
63
mysql-test/t/bug39022.test
Normal file
63
mysql-test/t/bug39022.test
Normal file
@ -0,0 +1,63 @@
|
||||
-- source include/have_log_bin.inc
|
||||
-- source include/have_innodb.inc
|
||||
-- source include/not_binlog_format_row.inc
|
||||
|
||||
--echo #
|
||||
--echo # Bug #39022: Mysql randomly crashing in lock_sec_rec_cons_read_sees
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1(a TINYINT NOT NULL,b TINYINT,PRIMARY KEY(b)) ENGINE=innodb;
|
||||
CREATE TABLE t2(d TINYINT NOT NULL,UNIQUE KEY(d)) ENGINE=innodb;
|
||||
INSERT INTO t1 VALUES (13,0),(8,1),(9,2),(6,3),
|
||||
(11,5),(11,6),(7,7),(7,8),(4,9),(6,10),(3,11),(11,12),
|
||||
(12,13),(7,14);
|
||||
INSERT INTO t2 VALUES (0),(1),(2),(3),(4),(5),(6),(7),(8),(9),(10),
|
||||
(11),(12),(13),(14);
|
||||
|
||||
connect (thread1, localhost, root,,);
|
||||
connect (thread2, localhost, root,,);
|
||||
|
||||
connection thread1;
|
||||
--echo # in thread1
|
||||
START TRANSACTION;
|
||||
|
||||
connection thread2;
|
||||
--echo # in thread2
|
||||
REPLACE INTO t2 VALUES (-17);
|
||||
SELECT d FROM t2,t1 WHERE d=(SELECT MAX(a) FROM t1 WHERE t1.a > t2.d);
|
||||
|
||||
connection thread1;
|
||||
--echo # in thread1
|
||||
REPLACE INTO t1(a,b) VALUES (67,20);
|
||||
|
||||
connection thread2;
|
||||
--echo # in thread2
|
||||
COMMIT;
|
||||
START TRANSACTION;
|
||||
REPLACE INTO t1(a,b) VALUES (65,-50);
|
||||
REPLACE INTO t2 VALUES (-91);
|
||||
send;
|
||||
SELECT d FROM t2,t1 WHERE d=(SELECT MAX(a) FROM t1 WHERE t1.a > t2.d); #waits
|
||||
|
||||
connection thread1;
|
||||
--echo # in thread1
|
||||
|
||||
--echo # should not crash
|
||||
--error ER_LOCK_DEADLOCK
|
||||
SELECT d FROM t2,t1 WHERE d=(SELECT MAX(a) FROM t1 WHERE t1.a > t2.d); #crashes
|
||||
|
||||
connection thread2;
|
||||
--echo # in thread2
|
||||
REAP;
|
||||
|
||||
disconnect thread2;
|
||||
--source include/wait_until_disconnected.inc
|
||||
|
||||
connection thread1;
|
||||
--echo # in thread1;
|
||||
disconnect thread1;
|
||||
--source include/wait_until_disconnected.inc
|
||||
|
||||
connection default;
|
||||
|
||||
DROP TABLE t1,t2;
|
@ -1807,17 +1807,17 @@ unlock tables;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#41441 repair csv table crashes debug server
|
||||
# Bug#33717 INSERT...(default) fails for enum. Crashes CSV tables, loads spaces for MyISAM
|
||||
#
|
||||
# Note: The test should be removed after Bug#33717 is fixed
|
||||
CREATE TABLE t1 (e enum('foo','bar') NOT NULL) ENGINE = CSV;
|
||||
INSERT INTO t1 VALUES();
|
||||
INSERT INTO t1 VALUES(default);
|
||||
INSERT INTO t1 VALUES(0);
|
||||
INSERT INTO t1 VALUES(3);
|
||||
INSERT INTO t1 VALUES(-1);
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
create table t1(a enum ('a') not null) engine=csv;
|
||||
insert into t1 values (2);
|
||||
--error ER_CRASHED_ON_USAGE
|
||||
select * from t1 limit 1;
|
||||
repair table t1;
|
||||
select * from t1 limit 1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug #40814 CSV engine does not parse \X characters when they occur in unquoted fields
|
||||
|
12
mysql-test/t/ctype_binary.test
Normal file
12
mysql-test/t/ctype_binary.test
Normal file
@ -0,0 +1,12 @@
|
||||
|
||||
set names binary;
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
--source include/ctype_numconv.inc
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
@ -58,3 +58,13 @@ SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
# End of 4.1 tests
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
--source include/ctype_numconv.inc
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
||||
|
@ -127,3 +127,14 @@ DROP TABLE `abc
|
||||
select hex(cast(_ascii 0x7f as char(1) character set latin1));
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
--source include/ctype_numconv.inc
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
||||
|
@ -1,4 +1,7 @@
|
||||
--source include/have_ucs2.inc
|
||||
--source include/have_utf8mb4.inc
|
||||
--source include/have_utf16.inc
|
||||
--source include/have_utf32.inc
|
||||
|
||||
--disable_warnings
|
||||
drop table if exists t1;
|
||||
@ -40,6 +43,24 @@ insert into t1 values ('a');
|
||||
select * from t1 where c1='b';
|
||||
drop table t1;
|
||||
|
||||
show collation like 'utf8mb4_test_ci';
|
||||
create table t1 (c1 char(1) character set utf8mb4 collate utf8mb4_test_ci);
|
||||
insert into t1 values ('a');
|
||||
select * from t1 where c1='b';
|
||||
drop table t1;
|
||||
|
||||
show collation like 'utf16_test_ci';
|
||||
create table t1 (c1 char(1) character set utf16 collate utf16_test_ci);
|
||||
insert into t1 values ('a');
|
||||
select * from t1 where c1='b';
|
||||
drop table t1;
|
||||
|
||||
show collation like 'utf32_test_ci';
|
||||
create table t1 (c1 char(1) character set utf32 collate utf32_test_ci);
|
||||
insert into t1 values ('a');
|
||||
select * from t1 where c1='b';
|
||||
drop table t1;
|
||||
|
||||
|
||||
#
|
||||
# Bug#41084 full-text index added to custom UCA collation not working
|
||||
|
@ -1,4 +1,7 @@
|
||||
-- source include/have_ucs2.inc
|
||||
-- source include/have_utf8mb4.inc
|
||||
-- source include/have_utf16.inc
|
||||
-- source include/have_utf32.inc
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
@ -211,3 +214,73 @@ SELECT min(comment),count(*) FROM t1 GROUP BY ucs2_f;
|
||||
DROP TABLE t1;
|
||||
|
||||
# End of 4.1 tests
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # WL#1213 Implement 4-byte UTF8, UTF16 and UTF32
|
||||
--echo # Testing that only utf8mb4 is superset for utf8
|
||||
--echo # No other Unicode character set pairs have superset/subset relations
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 (
|
||||
utf8 CHAR CHARACTER SET utf8,
|
||||
utf8mb4 CHAR CHARACTER SET utf8mb4,
|
||||
ucs2 CHAR CHARACTER SET ucs2,
|
||||
utf16 CHAR CHARACTER SET utf16,
|
||||
utf32 CHAR CHARACTER SET utf32
|
||||
);
|
||||
INSERT INTO t1 VALUES ('','','','','');
|
||||
|
||||
# utf8mb4 is superset only for utf8
|
||||
SELECT CHARSET(CONCAT(utf8, utf8mb4)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8, ucs2)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8, utf16)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8, utf32)) FROM t1;
|
||||
|
||||
|
||||
# utf8mb4 is superset only for utf8
|
||||
SELECT CHARSET(CONCAT(utf8mb4, utf8)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8mb4, ucs2)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8mb4, utf16)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf8mb4, utf32)) FROM t1;
|
||||
|
||||
|
||||
# ucs2 is not a superset for the other Unicode character sets
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(ucs2, utf8)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(ucs2, utf8mb4)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(ucs2, utf16)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(ucs2, utf32)) FROM t1;
|
||||
|
||||
|
||||
# utf16 is not a superset for the other Unicode character sets
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf16, utf8)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf16, ucs2)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf16, utf8mb4)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf16, utf32)) FROM t1;
|
||||
|
||||
|
||||
# utf32 is not a superset for the other Unicode character sets
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf32, utf8)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf32, ucs2)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf32, utf8mb4)) FROM t1;
|
||||
--error ER_CANT_AGGREGATE_2COLLATIONS
|
||||
SELECT CHARSET(CONCAT(utf32, utf16)) FROM t1;
|
||||
|
||||
DROP TABLE t1;
|
||||
|
@ -733,3 +733,17 @@ SELECT HEX(DAYNAME(19700101));
|
||||
SET character_set_connection=latin1;
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
SET NAMES latin1;
|
||||
SET collation_connection=ucs2_general_ci;
|
||||
--source include/ctype_numconv.inc
|
||||
SET NAMES latin1;
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
||||
|
733
mysql-test/t/ctype_utf16.test
Normal file
733
mysql-test/t/ctype_utf16.test
Normal file
@ -0,0 +1,733 @@
|
||||
-- source include/have_utf16.inc
|
||||
-- source include/have_utf8mb4.inc
|
||||
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
--enable_warnings
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
SET NAMES latin1;
|
||||
SET character_set_connection=utf16;
|
||||
select hex('a'), hex('a ');
|
||||
-- source include/endspace.inc
|
||||
|
||||
|
||||
# Check that incomplete utf16 characters in HEX notation
|
||||
# are left-padded with zeros
|
||||
#
|
||||
select hex(_utf16 0x44);
|
||||
select hex(_utf16 0x3344);
|
||||
select hex(_utf16 0x113344);
|
||||
|
||||
|
||||
# Check that 0x20 is only trimmed when it is
|
||||
# a part of real SPACE character, not just a part
|
||||
# of a multibyte sequence.
|
||||
# Note, CYRILLIC LETTER ER is used as an example, which
|
||||
# is stored as 0x0420 in utf16, thus contains 0x20 in the
|
||||
# low byte. The second character is THREE-PER-M, U+2004,
|
||||
# which contains 0x20 in the high byte.
|
||||
|
||||
CREATE TABLE t1 (word VARCHAR(64), word2 CHAR(64)) CHARACTER SET utf16;
|
||||
INSERT INTO t1 VALUES (_koi8r 0xF2, _koi8r 0xF2), (X'2004',X'2004');
|
||||
SELECT hex(word) FROM t1 ORDER BY word;
|
||||
SELECT hex(word2) FROM t1 ORDER BY word2;
|
||||
DELETE FROM t1;
|
||||
|
||||
#
|
||||
# Check that real spaces are correctly trimmed.
|
||||
#
|
||||
INSERT INTO t1 VALUES (X'042000200020',X'042000200020'), (X'200400200020', X'200400200020');
|
||||
SELECT hex(word) FROM t1 ORDER BY word;
|
||||
SELECT hex(word2) FROM t1 ORDER BY word2;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# Check LPAD/RPAD
|
||||
#
|
||||
SELECT hex(LPAD(_utf16 X'0420',10,_utf16 X'0421'));
|
||||
SELECT hex(LPAD(_utf16 X'0420',10,_utf16 X'04210422'));
|
||||
SELECT hex(LPAD(_utf16 X'0420',10,_utf16 X'042104220423'));
|
||||
SELECT hex(LPAD(_utf16 X'0420042104220423042404250426042704280429042A042B',10,_utf16 X'042104220423'));
|
||||
SELECT hex(LPAD(_utf16 X'D800DC00', 10, _utf16 X'0421'));
|
||||
SELECT hex(LPAD(_utf16 X'0421', 10, _utf16 X'D800DC00'));
|
||||
|
||||
SELECT hex(RPAD(_utf16 X'0420',10,_utf16 X'0421'));
|
||||
SELECT hex(RPAD(_utf16 X'0420',10,_utf16 X'04210422'));
|
||||
SELECT hex(RPAD(_utf16 X'0420',10,_utf16 X'042104220423'));
|
||||
SELECT hex(RPAD(_utf16 X'0420042104220423042404250426042704280429042A042B',10,_utf16 X'042104220423'));
|
||||
SELECT hex(RPAD(_utf16 X'D800DC00', 10, _utf16 X'0421'));
|
||||
SELECT hex(RPAD(_utf16 X'0421', 10, _utf16 X'D800DC00'));
|
||||
|
||||
CREATE TABLE t1 SELECT
|
||||
LPAD(_utf16 X'0420',10,_utf16 X'0421') l,
|
||||
RPAD(_utf16 X'0420',10,_utf16 X'0421') r;
|
||||
SHOW CREATE TABLE t1;
|
||||
select hex(l), hex(r) from t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
create table t1 (f1 char(30));
|
||||
insert into t1 values ("103000"), ("22720000"), ("3401200"), ("78000");
|
||||
select lpad(f1, 12, "-o-/") from t1;
|
||||
drop table t1;
|
||||
|
||||
######################################################
|
||||
#
|
||||
# Test of like
|
||||
#
|
||||
|
||||
SET NAMES latin1;
|
||||
SET character_set_connection=utf16;
|
||||
--source include/ctype_like.inc
|
||||
|
||||
SET NAMES utf8;
|
||||
SET character_set_connection=utf16;
|
||||
CREATE TABLE t1 (a VARCHAR(10) CHARACTER SET utf16);
|
||||
INSERT INTO t1 VALUES ('фыва'),('Фыва'),('фЫва'),('фыВа'),('фывА'),('ФЫВА');
|
||||
INSERT INTO t1 VALUES ('фывапролдж'),('Фывапролдж'),('фЫвапролдж'),('фыВапролдж');
|
||||
INSERT INTO t1 VALUES ('фывАпролдж'),('фываПролдж'),('фывапРолдж'),('фывапрОлдж');
|
||||
INSERT INTO t1 VALUES ('фывапроЛдж'),('фывапролДж'),('фывапролдЖ'),('ФЫВАПРОЛДЖ');
|
||||
SELECT * FROM t1 WHERE a LIKE '%фЫва%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE '%фЫв%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE 'фЫва%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE 'фЫва%' COLLATE utf16_bin ORDER BY BINARY a;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (word varchar(64) NOT NULL, PRIMARY KEY (word))
|
||||
ENGINE=MyISAM CHARACTER SET utf16;
|
||||
INSERT INTO t1 (word) VALUES ("cat");
|
||||
SELECT * FROM t1 WHERE word LIKE "c%";
|
||||
SELECT * FROM t1 WHERE word LIKE "ca_";
|
||||
SELECT * FROM t1 WHERE word LIKE "cat";
|
||||
SELECT * FROM t1 WHERE word LIKE _utf16 x'00630025'; # "c%"
|
||||
SELECT * FROM t1 WHERE word LIKE _utf16 x'00630061005F'; # "ca_"
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# Check that INSERT() works fine.
|
||||
# This invokes charpos() function.
|
||||
select insert(_utf16 0x006100620063,10,2,_utf16 0x006400650066);
|
||||
select insert(_utf16 0x006100620063,1,2,_utf16 0x006400650066);
|
||||
|
||||
########################################################
|
||||
#
|
||||
# Bug 1264
|
||||
#
|
||||
# Description:
|
||||
#
|
||||
# When using a ucs2 table in MySQL,
|
||||
# either with ucs2_general_ci or ucs2_bin collation,
|
||||
# words are returned in an incorrect order when using ORDER BY
|
||||
# on an _indexed_ CHAR or VARCHAR column. They are sorted with
|
||||
# the longest word *first* instead of last. I.E. The word "aardvark"
|
||||
# is in the results before the word "a".
|
||||
#
|
||||
# If there is no index for the column, the problem does not occur.
|
||||
#
|
||||
# Interestingly, if there is no second column, the words are returned
|
||||
# in the correct order.
|
||||
#
|
||||
# According to EXPLAIN, it looks like when the output includes columns that
|
||||
# are not part of the index sorted on, it does a filesort, which fails.
|
||||
# Using a straight index yields correct results.
|
||||
|
||||
SET NAMES latin1;
|
||||
|
||||
#
|
||||
# Two fields, index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word VARCHAR(64),
|
||||
bar INT(11) default 0,
|
||||
PRIMARY KEY (word))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf16
|
||||
COLLATE utf16_general_ci ;
|
||||
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a");
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY word;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
EXPLAIN SELECT word FROM t1 ORDER BY word;
|
||||
SELECT word FROM t1 ORDER by word;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# One field, index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word VARCHAR(64) ,
|
||||
PRIMARY KEY (word))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf16
|
||||
COLLATE utf16_general_ci;
|
||||
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a");
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY WORD;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# Two fields, no index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word TEXT,
|
||||
bar INT(11) AUTO_INCREMENT,
|
||||
PRIMARY KEY (bar))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf16
|
||||
COLLATE utf16_general_ci ;
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a" );
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY word;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
EXPLAIN SELECT word FROM t1 ORDER BY word;
|
||||
SELECT word FROM t1 ORDER BY word;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# END OF Bug 1264 test
|
||||
#
|
||||
########################################################
|
||||
|
||||
|
||||
#
|
||||
# Check alignment for from-binary-conversion with CAST and CONVERT
|
||||
#
|
||||
SELECT hex(cast(0xAA as char character set utf16));
|
||||
SELECT hex(convert(0xAA using utf16));
|
||||
|
||||
#
|
||||
# Check alignment for string types
|
||||
#
|
||||
CREATE TABLE t1 (a char(10) character set utf16);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a varchar(10) character set utf16);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a text character set utf16);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a mediumtext character set utf16);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a longtext character set utf16);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
##
|
||||
## Bug #5024 Server crashes with queries on fields
|
||||
## with certain charset/collation settings
|
||||
##
|
||||
##
|
||||
#create table t1 (s1 char character set utf16 collate utf16_czech_ci);
|
||||
#insert into t1 values ('0'),('1'),('2'),('a'),('b'),('c');
|
||||
#select s1 from t1 where s1 > 'a' order by s1;
|
||||
#drop table t1;
|
||||
#
|
||||
|
||||
#
|
||||
# Bug #5081 : UCS2 fields are filled with '0x2020'
|
||||
# after extending field length
|
||||
#
|
||||
create table t1(a char(1)) default charset utf16;
|
||||
insert into t1 values ('a'),('b'),('c');
|
||||
alter table t1 modify a char(5);
|
||||
select a, hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Check prepare statement from an UTF16 string
|
||||
#
|
||||
set @ivar= 1234;
|
||||
set @str1 = 'select ?';
|
||||
set @str2 = convert(@str1 using utf16);
|
||||
prepare stmt1 from @str2;
|
||||
execute stmt1 using @ivar;
|
||||
|
||||
#
|
||||
# Check that utf16 works with ENUM and SET type
|
||||
#
|
||||
set names utf8;
|
||||
create table t1 (a enum('x','y','z') character set utf16);
|
||||
show create table t1;
|
||||
insert into t1 values ('x');
|
||||
insert into t1 values ('y');
|
||||
insert into t1 values ('z');
|
||||
select a, hex(a) from t1 order by a;
|
||||
alter table t1 change a a enum('x','y','z','d','e','ä','ö','ü') character set utf16;
|
||||
show create table t1;
|
||||
insert into t1 values ('D');
|
||||
insert into t1 values ('E ');
|
||||
insert into t1 values ('ä');
|
||||
insert into t1 values ('ö');
|
||||
insert into t1 values ('ü');
|
||||
select a, hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
create table t1 (a set ('x','y','z','ä','ö','ü') character set utf16);
|
||||
show create table t1;
|
||||
insert into t1 values ('x');
|
||||
insert into t1 values ('y');
|
||||
insert into t1 values ('z');
|
||||
insert into t1 values ('x,y');
|
||||
insert into t1 values ('x,y,z,ä,ö,ü');
|
||||
select a, hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#7302 UCS2 data in ENUM fields get truncated when new column is added
|
||||
#
|
||||
create table t1(a enum('a','b','c')) default character set utf16;
|
||||
insert into t1 values('a'),('b'),('c');
|
||||
alter table t1 add b char(1);
|
||||
show warnings;
|
||||
select * from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
SET NAMES latin1;
|
||||
SET collation_connection='utf16_general_ci';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
SET NAMES latin1;
|
||||
SET collation_connection='utf16_bin';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
|
||||
#
|
||||
# Bug#10344 Some string functions fail for UCS2
|
||||
#
|
||||
select hex(substr(_utf16 0x00e400e50068,1));
|
||||
select hex(substr(_utf16 0x00e400e50068,2));
|
||||
select hex(substr(_utf16 0x00e400e50068,3));
|
||||
select hex(substr(_utf16 0x00e400e50068,-1));
|
||||
select hex(substr(_utf16 0x00e400e50068,-2));
|
||||
select hex(substr(_utf16 0x00e400e50068,-3));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,1));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,2));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,3));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,-1));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,-2));
|
||||
select hex(substr(_utf16 0x00e400e5D800DC00,-3));
|
||||
|
||||
SET NAMES latin1;
|
||||
|
||||
##
|
||||
## Bug#8235
|
||||
##
|
||||
## This bug also helped to find another problem that
|
||||
## INSERT of a UCS2 string containing a negative number
|
||||
## into a unsigned int column didn't produce warnings.
|
||||
## This test covers both problems.
|
||||
##
|
||||
##SET collation_connection='ucs2_swedish_ci';
|
||||
##CREATE TABLE t1 (Field1 int(10) default '0');
|
||||
### no warnings, negative numbers are allowed
|
||||
##INSERT INTO t1 VALUES ('-1');
|
||||
##SELECT * FROM t1;
|
||||
##DROP TABLE t1;
|
||||
##CREATE TABLE t1 (Field1 int(10) unsigned default '0');
|
||||
### this should generate a "Data truncated" warning
|
||||
##INSERT INTO t1 VALUES ('-1');
|
||||
##DROP TABLE t1;
|
||||
##SET NAMES latin1;
|
||||
|
||||
###
|
||||
### Bug #14583 Bug on query using a LIKE on indexed field with ucs2_bin collation
|
||||
###
|
||||
##--disable_warnings
|
||||
##create table t1(f1 varchar(5) CHARACTER SET utf16 COLLATE utf16_bin NOT NULL) engine=InnoDB;
|
||||
##--enable_warnings
|
||||
##insert into t1 values('a');
|
||||
##create index t1f1 on t1(f1);
|
||||
##select f1 from t1 where f1 like 'a%';
|
||||
##drop table t1;
|
||||
|
||||
#
|
||||
# Bug#9442 Set parameter make query fail if column character set is UCS2
|
||||
#
|
||||
create table t1 (utext varchar(20) character set utf16);
|
||||
insert into t1 values ("lily");
|
||||
insert into t1 values ("river");
|
||||
prepare stmt from 'select utext from t1 where utext like ?';
|
||||
set @param1='%%';
|
||||
execute stmt using @param1;
|
||||
execute stmt using @param1;
|
||||
select utext from t1 where utext like '%%';
|
||||
drop table t1;
|
||||
deallocate prepare stmt;
|
||||
|
||||
#
|
||||
# Bug#22052 Trailing spaces are not removed from UNICODE fields in an index
|
||||
#
|
||||
create table t1 (
|
||||
a char(10) character set utf16 not null,
|
||||
index a (a)
|
||||
) engine=myisam;
|
||||
insert into t1 values (repeat(0x201f, 10));
|
||||
insert into t1 values (repeat(0x2020, 10));
|
||||
insert into t1 values (repeat(0x2021, 10));
|
||||
# make sure "index read" is used
|
||||
explain select hex(a) from t1 order by a;
|
||||
select hex(a) from t1 order by a;
|
||||
alter table t1 drop index a;
|
||||
select hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
##
|
||||
## Bug #20076: server crashes for a query with GROUP BY if MIN/MAX aggregation
|
||||
## over a 'ucs2' field uses a temporary table
|
||||
##
|
||||
##CREATE TABLE t1 (id int, s char(5) CHARACTER SET ucs2 COLLATE ucs2_unicode_ci);
|
||||
##INSERT INTO t1 VALUES (1, 'ZZZZZ'), (1, 'ZZZ'), (2, 'ZZZ'), (2, 'ZZZZZ');
|
||||
##SELECT id, MIN(s) FROM t1 GROUP BY id;
|
||||
##DROP TABLE t1;
|
||||
|
||||
###
|
||||
### Bug #20536: md5() with GROUP BY and UCS2 return different results on myisam/innodb
|
||||
###
|
||||
##
|
||||
##--disable_warnings
|
||||
##drop table if exists bug20536;
|
||||
##--enable_warnings
|
||||
##
|
||||
##set names latin1;
|
||||
##create table bug20536 (id bigint not null auto_increment primary key, name
|
||||
##varchar(255) character set ucs2 not null);
|
||||
##insert into `bug20536` (`id`,`name`) values (1, _latin1 x'7465737431'), (2, "'test\\_2'");
|
||||
##select md5(name) from bug20536;
|
||||
##select sha1(name) from bug20536;
|
||||
##select make_set(3, name, upper(name)) from bug20536;
|
||||
##select export_set(5, name, upper(name)) from bug20536;
|
||||
##select export_set(5, name, upper(name), ",", 5) from bug20536;
|
||||
|
||||
#
|
||||
# Bug #20108: corrupted default enum value for a ucs2 field
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
status enum('active','passive') character set utf16 collate utf16_general_ci
|
||||
NOT NULL default 'passive'
|
||||
);
|
||||
SHOW CREATE TABLE t1;
|
||||
ALTER TABLE t1 ADD a int NOT NULL AFTER status;
|
||||
SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
##CREATE TABLE t2 (
|
||||
## status enum('active','passive') collate ucs2_turkish_ci
|
||||
## NOT NULL default 'passive'
|
||||
##);
|
||||
##SHOW CREATE TABLE t2;
|
||||
##ALTER TABLE t2 ADD a int NOT NULL AFTER status;
|
||||
##DROP TABLE t2;
|
||||
|
||||
|
||||
--echo End of 4.1 tests
|
||||
|
||||
#
|
||||
# Conversion from an UTF16 string to a decimal column
|
||||
#
|
||||
CREATE TABLE t1 (a varchar(64) character set utf16, b decimal(10,3));
|
||||
INSERT INTO t1 VALUES ("1.1", 0), ("2.1", 0);
|
||||
update t1 set b=a;
|
||||
SELECT *, hex(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# Bug#9442 Set parameter make query fail if column character set is UCS2
|
||||
#
|
||||
create table t1 (utext varchar(20) character set utf16);
|
||||
insert into t1 values ("lily");
|
||||
insert into t1 values ("river");
|
||||
prepare stmt from 'select utext from t1 where utext like ?';
|
||||
set @param1='%%';
|
||||
execute stmt using @param1;
|
||||
execute stmt using @param1;
|
||||
select utext from t1 where utext like '%%';
|
||||
drop table t1;
|
||||
deallocate prepare stmt;
|
||||
|
||||
#
|
||||
# Bug#22638 SOUNDEX broken for international characters
|
||||
#
|
||||
set names latin1;
|
||||
set character_set_connection=utf16;
|
||||
select soundex(''),soundex('he'),soundex('hello all folks'),soundex('#3556 in bugdb');
|
||||
select hex(soundex('')),hex(soundex('he')),hex(soundex('hello all folks')),hex(soundex('#3556 in bugdb'));
|
||||
select 'mood' sounds like 'mud';
|
||||
# Cyrillic A, BE, VE
|
||||
select hex(soundex(_utf16 0x041004110412));
|
||||
# Make sure that "U+00BF INVERTED QUESTION MARK" is not considered as letter
|
||||
select hex(soundex(_utf16 0x00BF00C0));
|
||||
set names latin1;
|
||||
|
||||
#
|
||||
# Bug #14290: character_maximum_length for text fields
|
||||
#
|
||||
create table t1(a blob, b text charset utf16);
|
||||
select data_type, character_octet_length, character_maximum_length
|
||||
from information_schema.columns where table_name='t1';
|
||||
drop table t1;
|
||||
|
||||
|
||||
set names latin1;
|
||||
set collation_connection=utf16_general_ci;
|
||||
#
|
||||
# Testing cs->coll->instr()
|
||||
#
|
||||
select position('bb' in 'abba');
|
||||
|
||||
#
|
||||
# Testing cs->coll->hash_sort()
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf16) engine=heap;
|
||||
insert into t1 values ('a'),('A'),('b'),('B');
|
||||
select * from t1 where a='a' order by binary a;
|
||||
select hex(min(binary a)),count(*) from t1 group by a;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->numchars()
|
||||
#
|
||||
select char_length('abcd'), octet_length('abcd');
|
||||
select char_length(_utf16 0xD800DC00), octet_length(_utf16 0xD800DC00);
|
||||
select char_length(_utf16 0xD87FDFFF), octet_length(_utf16 0xD87FDFFF);
|
||||
|
||||
#
|
||||
# Testing cs->cset->charpos()
|
||||
#
|
||||
select left('abcd',2);
|
||||
select hex(left(_utf16 0xD800DC00D87FDFFF, 1));
|
||||
select hex(right(_utf16 0xD800DC00D87FDFFF, 1));
|
||||
|
||||
#
|
||||
# Testing cs->cset->well_formed_length()
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf16);
|
||||
# Bad sequences
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf16 0xD800);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf16 0xDC00);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf16 0xD800D800);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf16 0xD800E800);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf16 0xD8000800);
|
||||
# Good sequences
|
||||
insert into t1 values (_utf16 0xD800DC00);
|
||||
insert into t1 values (_utf16 0xD800DCFF);
|
||||
insert into t1 values (_utf16 0xDBFFDC00);
|
||||
insert into t1 values (_utf16 0xDBFFDCFF);
|
||||
select hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#32393 Character sets: illegal characters in utf16 columns
|
||||
#
|
||||
# Tests that cs->cset->wc_mb() doesn't accept surrogate parts
|
||||
#
|
||||
# via alter
|
||||
#
|
||||
create table t1 (s1 varchar(50) character set ucs2);
|
||||
insert into t1 values (0xdf84);
|
||||
alter table t1 modify column s1 varchar(50) character set utf16;
|
||||
select hex(s1) from t1;
|
||||
drop table t1;
|
||||
#
|
||||
# via update
|
||||
#
|
||||
create table t1 (s1 varchar(5) character set ucs2, s2 varchar(5) character set utf16);
|
||||
insert into t1 (s1) values (0xdf84);
|
||||
update t1 set s2 = s1;
|
||||
select hex(s2) from t1;
|
||||
drop table t1;
|
||||
|
||||
|
||||
|
||||
#
|
||||
# Testing cs->cset->lengthsp()
|
||||
#
|
||||
create table t1 (a char(10)) character set utf16;
|
||||
insert into t1 values ('a ');
|
||||
select hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->caseup() and cs->cset->casedn()
|
||||
#
|
||||
select upper('abcd'), lower('ABCD');
|
||||
|
||||
#
|
||||
# TODO: str_to_datetime() is broken and doesn't work with ucs2 and utf16
|
||||
# Testing cs->cset->snprintf()
|
||||
#
|
||||
#create table t1 (a date);
|
||||
#insert into t1 values ('2007-09-16');
|
||||
#select * from t1;
|
||||
#drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->l10tostr
|
||||
# !!! Not used in the code
|
||||
|
||||
#
|
||||
# Testing cs->cset->ll10tostr
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf16);
|
||||
insert into t1 values (123456);
|
||||
select a, hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
|
||||
# Testing cs->cset->fill
|
||||
# SOUNDEX fills strings with DIGIT ZERO up to four characters
|
||||
select hex(soundex('a'));
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntol
|
||||
# !!! Not used in the code
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoul
|
||||
#
|
||||
create table t1 (a enum ('a','b','c')) character set utf16;
|
||||
insert into t1 values ('1');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoll and cs->cset->strntoull
|
||||
#
|
||||
set names latin1;
|
||||
select hex(conv(convert('123' using utf16), -10, 16));
|
||||
select hex(conv(convert('123' using utf16), 10, 16));
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntod
|
||||
#
|
||||
set names latin1;
|
||||
set character_set_connection=utf16;
|
||||
select 1.1 + '1.2';
|
||||
select 1.1 + '1.2xxx';
|
||||
|
||||
# Testing strntoll10_utf16
|
||||
# Testing cs->cset->strtoll10
|
||||
select left('aaa','1');
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoull10rnd
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values ('-1234.1e2');
|
||||
insert into t1 values ('-1234.1e2xxxx');
|
||||
insert into t1 values ('-1234.1e2 ');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->scan
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values ('1 ');
|
||||
insert into t1 values ('1 x');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing auto-conversion to TEXT
|
||||
#
|
||||
create table t1 (a varchar(17000) character set utf16);
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing that maximim possible key length is 1000 bytes
|
||||
#
|
||||
create table t1 (a varchar(250) character set utf16 primary key);
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
--error ER_TOO_LONG_KEY
|
||||
create table t1 (a varchar(334) character set utf16 primary key);
|
||||
|
||||
#
|
||||
# Conversion to utf8
|
||||
#
|
||||
create table t1 (a char(1) character set utf16);
|
||||
insert into t1 values (0xD800DC00),(0xD800DCFF),(0xDB7FDC00),(0xDB7FDCFF);
|
||||
insert into t1 values (0x00C0), (0x00FF),(0xE000), (0xFFFF);
|
||||
select hex(a), hex(@a:=convert(a using utf8mb4)), hex(convert(@a using utf16)) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Test basic regex functionality
|
||||
#
|
||||
set collation_connection=utf16_general_ci;
|
||||
--source include/ctype_regex.inc
|
||||
set names latin1;
|
||||
|
||||
#
|
||||
# Test how character set works with date/time
|
||||
#
|
||||
SET collation_connection=utf16_general_ci;
|
||||
--source include/ctype_datetime.inc
|
||||
SET NAMES latin1;
|
||||
|
||||
#
|
||||
# Bug#33073 Character sets: ordering fails with utf32
|
||||
#
|
||||
SET collation_connection=utf16_general_ci;
|
||||
CREATE TABLE t1 AS SELECT repeat('a',2) as s1 LIMIT 0;
|
||||
SHOW CREATE TABLE t1;
|
||||
INSERT INTO t1 VALUES ('ab'),('AE'),('ab'),('AE');
|
||||
SELECT * FROM t1 ORDER BY s1;
|
||||
SET max_sort_length=4;
|
||||
SELECT * FROM t1 ORDER BY s1;
|
||||
DROP TABLE t1;
|
||||
SET max_sort_length=DEFAULT;
|
||||
SET NAMES latin1;
|
||||
|
||||
|
||||
#
|
||||
## TODO: add tests for all engines
|
||||
#
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
290
mysql-test/t/ctype_utf16_uca.test
Normal file
290
mysql-test/t/ctype_utf16_uca.test
Normal file
@ -0,0 +1,290 @@
|
||||
-- source include/have_utf16.inc
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
--enable_warnings
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
set names utf8;
|
||||
set collation_connection=utf16_unicode_ci;
|
||||
select hex('a'), hex('a ');
|
||||
-- source include/endspace.inc
|
||||
|
||||
#
|
||||
# Bug #6787 LIKE not working properly with _ and utf8 data
|
||||
#
|
||||
select 'c' like '\_' as want0;
|
||||
|
||||
#
|
||||
# Bug #5679 utf8_unicode_ci LIKE--trailing % doesn't equal zero characters
|
||||
#
|
||||
CREATE TABLE t (
|
||||
c char(20) NOT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARACTER SET utf16 COLLATE utf16_unicode_ci;
|
||||
INSERT INTO t VALUES ('a'),('ab'),('aba');
|
||||
ALTER TABLE t ADD INDEX (c);
|
||||
SELECT c FROM t WHERE c LIKE 'a%';
|
||||
DROP TABLE t;
|
||||
|
||||
|
||||
create table t1 (c1 char(10) character set utf16 collate utf16_bin);
|
||||
|
||||
#
|
||||
# Basic Latin
|
||||
#
|
||||
insert into t1 values ('A'),('a');
|
||||
insert into t1 values ('B'),('b');
|
||||
insert into t1 values ('C'),('c');
|
||||
insert into t1 values ('D'),('d');
|
||||
insert into t1 values ('E'),('e');
|
||||
insert into t1 values ('F'),('f');
|
||||
insert into t1 values ('G'),('g');
|
||||
insert into t1 values ('H'),('h');
|
||||
insert into t1 values ('I'),('i');
|
||||
insert into t1 values ('J'),('j');
|
||||
insert into t1 values ('K'),('k');
|
||||
insert into t1 values ('L'),('l');
|
||||
insert into t1 values ('M'),('m');
|
||||
insert into t1 values ('N'),('n');
|
||||
insert into t1 values ('O'),('o');
|
||||
insert into t1 values ('P'),('p');
|
||||
insert into t1 values ('Q'),('q');
|
||||
insert into t1 values ('R'),('r');
|
||||
insert into t1 values ('S'),('s');
|
||||
insert into t1 values ('T'),('t');
|
||||
insert into t1 values ('U'),('u');
|
||||
insert into t1 values ('V'),('v');
|
||||
insert into t1 values ('W'),('w');
|
||||
insert into t1 values ('X'),('x');
|
||||
insert into t1 values ('Y'),('y');
|
||||
insert into t1 values ('Z'),('z');
|
||||
|
||||
#
|
||||
# Latin1 suppliment
|
||||
#
|
||||
insert into t1 values (0x00e0),(0x00c0);
|
||||
insert into t1 values (0x00e1),(0x00c1);
|
||||
insert into t1 values (0x00e2),(0x00c2);
|
||||
insert into t1 values (0x00e3),(0x00c3);
|
||||
insert into t1 values (0x00e4),(0x00c4);
|
||||
insert into t1 values (0x00e5),(0x00c5);
|
||||
insert into t1 values (0x00e6),(0x00c6);
|
||||
insert into t1 values (0x00e7),(0x00c7);
|
||||
insert into t1 values (0x00e8),(0x00c8);
|
||||
insert into t1 values (0x00e9),(0x00c9);
|
||||
insert into t1 values (0x00ea),(0x00ca);
|
||||
insert into t1 values (0x00eb),(0x00cb);
|
||||
insert into t1 values (0x00ec),(0x00cc);
|
||||
insert into t1 values (0x00ed),(0x00cd);
|
||||
insert into t1 values (0x00ee),(0x00ce);
|
||||
insert into t1 values (0x00ef),(0x00cf);
|
||||
|
||||
insert into t1 values (0x00f0),(0x00d0);
|
||||
insert into t1 values (0x00f1),(0x00d1);
|
||||
insert into t1 values (0x00f2),(0x00d2);
|
||||
insert into t1 values (0x00f3),(0x00d3);
|
||||
insert into t1 values (0x00f4),(0x00d4);
|
||||
insert into t1 values (0x00f5),(0x00d5);
|
||||
insert into t1 values (0x00f6),(0x00d6);
|
||||
insert into t1 values (0x00f7),(0x00d7);
|
||||
insert into t1 values (0x00f8),(0x00d8);
|
||||
insert into t1 values (0x00f9),(0x00d9);
|
||||
insert into t1 values (0x00fa),(0x00da);
|
||||
insert into t1 values (0x00fb),(0x00db);
|
||||
insert into t1 values (0x00fc),(0x00dc);
|
||||
insert into t1 values (0x00fd),(0x00dd);
|
||||
insert into t1 values (0x00fe),(0x00de);
|
||||
insert into t1 values (0x00ff),(0x00df);
|
||||
|
||||
#
|
||||
# Latin extended-A, 0100-017F
|
||||
#
|
||||
insert into t1 values (0x0100),(0x0101),(0x0102),(0x0103);
|
||||
insert into t1 values (0x0104),(0x0105),(0x0106),(0x0107);
|
||||
insert into t1 values (0x0108),(0x0109),(0x010a),(0x010b);
|
||||
insert into t1 values (0x010c),(0x010d),(0x010e),(0x010f);
|
||||
insert into t1 values (0x0110),(0x0111),(0x0112),(0x0113);
|
||||
insert into t1 values (0x0114),(0x0115),(0x0116),(0x0117);
|
||||
insert into t1 values (0x0118),(0x0119),(0x011a),(0x011b);
|
||||
insert into t1 values (0x011c),(0x011d),(0x011e),(0x011f);
|
||||
insert into t1 values (0x0120),(0x0121),(0x0122),(0x0123);
|
||||
insert into t1 values (0x0124),(0x0125),(0x0126),(0x0127);
|
||||
insert into t1 values (0x0128),(0x0129),(0x012a),(0x012b);
|
||||
insert into t1 values (0x012c),(0x012d),(0x012e),(0x012f);
|
||||
insert into t1 values (0x0130),(0x0131),(0x0132),(0x0133);
|
||||
insert into t1 values (0x0134),(0x0135),(0x0136),(0x0137);
|
||||
insert into t1 values (0x0138),(0x0139),(0x013a),(0x013b);
|
||||
insert into t1 values (0x013c),(0x013d),(0x013e),(0x013f);
|
||||
insert into t1 values (0x0140),(0x0141),(0x0142),(0x0143);
|
||||
insert into t1 values (0x0144),(0x0145),(0x0146),(0x0147);
|
||||
insert into t1 values (0x0148),(0x0149),(0x014a),(0x014b);
|
||||
insert into t1 values (0x014c),(0x014d),(0x014e),(0x014f);
|
||||
insert into t1 values (0x0150),(0x0151),(0x0152),(0x0153);
|
||||
insert into t1 values (0x0154),(0x0155),(0x0156),(0x0157);
|
||||
insert into t1 values (0x0158),(0x0159),(0x015a),(0x015b);
|
||||
insert into t1 values (0x015c),(0x015d),(0x015e),(0x015f);
|
||||
insert into t1 values (0x0160),(0x0161),(0x0162),(0x0163);
|
||||
insert into t1 values (0x0164),(0x0165),(0x0166),(0x0167);
|
||||
insert into t1 values (0x0168),(0x0169),(0x016a),(0x016b);
|
||||
insert into t1 values (0x016c),(0x016d),(0x016e),(0x016f);
|
||||
insert into t1 values (0x0170),(0x0171),(0x0172),(0x0173);
|
||||
insert into t1 values (0x0174),(0x0175),(0x0176),(0x0177);
|
||||
insert into t1 values (0x0178),(0x0179),(0x017a),(0x017b);
|
||||
insert into t1 values (0x017c),(0x017d),(0x017e),(0x017f);
|
||||
|
||||
#
|
||||
# Latin extended-B, 0180-024F
|
||||
#
|
||||
insert into t1 values (0x0180),(0x0181),(0x0182),(0x0183);
|
||||
insert into t1 values (0x0184),(0x0185),(0x0186),(0x0187);
|
||||
insert into t1 values (0x0188),(0x0189),(0x018a),(0x018b);
|
||||
insert into t1 values (0x018c),(0x018d),(0x018e),(0x018f);
|
||||
insert into t1 values (0x0190),(0x0191),(0x0192),(0x0193);
|
||||
insert into t1 values (0x0194),(0x0195),(0x0196),(0x0197);
|
||||
insert into t1 values (0x0198),(0x0199),(0x019a),(0x019b);
|
||||
insert into t1 values (0x019c),(0x019d),(0x019e),(0x019f);
|
||||
insert into t1 values (0x01a0),(0x01a1),(0x01a2),(0x01a3);
|
||||
insert into t1 values (0x01a4),(0x01a5),(0x01a6),(0x01a7);
|
||||
insert into t1 values (0x01a8),(0x01a9),(0x01aa),(0x01ab);
|
||||
insert into t1 values (0x01ac),(0x01ad),(0x01ae),(0x01af);
|
||||
insert into t1 values (0x01b0),(0x01b1),(0x01b2),(0x01b3);
|
||||
insert into t1 values (0x01b4),(0x01b5),(0x01b6),(0x01b7);
|
||||
insert into t1 values (0x01b8),(0x01b9),(0x01ba),(0x01bb);
|
||||
insert into t1 values (0x01bc),(0x01bd),(0x01be),(0x01bf);
|
||||
insert into t1 values (0x01c0),(0x01c1),(0x01c2),(0x01c3);
|
||||
insert into t1 values (0x01c4),(0x01c5),(0x01c6),(0x01c7);
|
||||
insert into t1 values (0x01c8),(0x01c9),(0x01ca),(0x01cb);
|
||||
insert into t1 values (0x01cc),(0x01cd),(0x01ce),(0x01cf);
|
||||
insert into t1 values (0x01d0),(0x01d1),(0x01d2),(0x01d3);
|
||||
insert into t1 values (0x01d4),(0x01d5),(0x01d6),(0x01d7);
|
||||
insert into t1 values (0x01d8),(0x01d9),(0x01da),(0x01db);
|
||||
insert into t1 values (0x01dc),(0x01dd),(0x01de),(0x01df);
|
||||
insert into t1 values (0x01e0),(0x01e1),(0x01e2),(0x01e3);
|
||||
insert into t1 values (0x01e4),(0x01e5),(0x01e6),(0x01e7);
|
||||
insert into t1 values (0x01e8),(0x01e9),(0x01ea),(0x01eb);
|
||||
insert into t1 values (0x01ec),(0x01ed),(0x01ee),(0x01ef);
|
||||
insert into t1 values (0x01f0),(0x01f1),(0x01f2),(0x01f3);
|
||||
insert into t1 values (0x01f4),(0x01f5),(0x01f6),(0x01f7);
|
||||
insert into t1 values (0x01f8),(0x01f9),(0x01fa),(0x01fb);
|
||||
insert into t1 values (0x01fc),(0x01fd),(0x01fe),(0x01ff);
|
||||
|
||||
|
||||
insert into t1 values ('AA'),('Aa'),('aa'),('aA');
|
||||
insert into t1 values ('CH'),('Ch'),('ch'),('cH');
|
||||
insert into t1 values ('DZ'),('Dz'),('dz'),('dZ');
|
||||
insert into t1 values ('IJ'),('Ij'),('ij'),('iJ');
|
||||
insert into t1 values ('LJ'),('Lj'),('lj'),('lJ');
|
||||
insert into t1 values ('LL'),('Ll'),('ll'),('lL');
|
||||
insert into t1 values ('NJ'),('Nj'),('nj'),('nJ');
|
||||
insert into t1 values ('OE'),('Oe'),('oe'),('oE');
|
||||
insert into t1 values ('SS'),('Ss'),('ss'),('sS');
|
||||
insert into t1 values ('RR'),('Rr'),('rr'),('rR');
|
||||
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_unicode_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_icelandic_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_latvian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_romanian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_slovenian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_polish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_estonian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_spanish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_swedish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_turkish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_czech_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_danish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_lithuanian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_slovak_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_spanish2_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_roman_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_esperanto_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf16_hungarian_ci;
|
||||
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#5324
|
||||
#
|
||||
SET NAMES utf8;
|
||||
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf16 COLLATE utf16_general_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (0x039C03C903B403B11F770308);
|
||||
#Check one row
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025 COLLATE utf16_general_ci;
|
||||
INSERT INTO t1 VALUES (0x039C03C903B4);
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025
|
||||
COLLATE utf16_general_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf16 COLLATE utf16_unicode_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (0x039C03C903B403B11F770308);
|
||||
#Check one row
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025 COLLATE utf16_unicode_ci;
|
||||
INSERT INTO t1 VALUES (0x039C03C903B4);
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025
|
||||
COLLATE utf16_unicode_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf16 COLLATE utf16_unicode_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (0x039C03C903B403B11F770308);
|
||||
#Check one row row
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025 COLLATE utf16_unicode_ci;
|
||||
INSERT INTO t1 VALUES (0x039C03C903B4);
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE _utf16 0x039C0025
|
||||
COLLATE utf16_unicode_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
SET NAMES utf8;
|
||||
SET @test_character_set='utf16';
|
||||
SET @test_collation='utf16_swedish_ci';
|
||||
-- source include/ctype_common.inc
|
||||
|
||||
|
||||
SET collation_connection='utf16_unicode_ci';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
|
||||
--echo End of 4.1 tests
|
||||
|
||||
#
|
||||
# Check UPPER/LOWER changing length
|
||||
#
|
||||
# Result shorter than argument
|
||||
CREATE TABLE t1 (id int, a varchar(30) character set utf16);
|
||||
INSERT INTO t1 VALUES (1, 0x01310069), (2, 0x01310131);
|
||||
INSERT INTO t1 VALUES (3, 0x00690069), (4, 0x01300049);
|
||||
INSERT INTO t1 VALUES (5, 0x01300130), (6, 0x00490049);
|
||||
SELECT a, length(a) la, @l:=lower(a) l, length(@l) ll, @u:=upper(a) u, length(@u) lu
|
||||
FROM t1 ORDER BY id;
|
||||
ALTER TABLE t1 MODIFY a VARCHAR(30) character set utf16 collate utf16_turkish_ci;
|
||||
SELECT a, length(a) la, @l:=lower(a) l, length(@l) ll, @u:=upper(a) u, length(@u) lu
|
||||
FROM t1 ORDER BY id;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# Bug #27079 Crash while grouping empty ucs2 strings
|
||||
#
|
||||
CREATE TABLE t1 (
|
||||
c1 text character set utf16 collate utf16_polish_ci NOT NULL
|
||||
) ENGINE=MyISAM;
|
||||
insert into t1 values (''),('a');
|
||||
SELECT COUNT(*), c1 FROM t1 GROUP BY c1;
|
||||
DROP TABLE IF EXISTS t1;
|
||||
|
||||
|
||||
#
|
||||
# Test basic regex functionality
|
||||
#
|
||||
set collation_connection=utf16_unicode_ci;
|
||||
--source include/ctype_regex.inc
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
784
mysql-test/t/ctype_utf32.test
Normal file
784
mysql-test/t/ctype_utf32.test
Normal file
@ -0,0 +1,784 @@
|
||||
-- source include/have_utf32.inc
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
--enable_warnings
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
SET NAMES latin1;
|
||||
SET character_set_connection=utf32;
|
||||
select hex('a'), hex('a ');
|
||||
-- source include/endspace.inc
|
||||
|
||||
#
|
||||
# Check that incomplete utf32 characters in HEX notation
|
||||
# are left-padded with zeros
|
||||
#
|
||||
select hex(_utf32 0x44);
|
||||
select hex(_utf32 0x3344);
|
||||
select hex(_utf32 0x103344);
|
||||
|
||||
select hex(_utf32 X'44');
|
||||
select hex(_utf32 X'3344');
|
||||
select hex(_utf32 X'103344');
|
||||
|
||||
|
||||
#
|
||||
# Check that 0x20 is only trimmed when it is
|
||||
# a part of real SPACE character, not just a part
|
||||
# of a multibyte sequence.
|
||||
# Note, CYRILLIC LETTER ER is used as an example, which
|
||||
# is stored as 0x0420 in UCS2, thus contains 0x20 in the
|
||||
# low byte. The second character is THREE-PER-M, U+2004,
|
||||
# which contains 0x20 in the high byte.
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (word VARCHAR(64), word2 CHAR(64)) CHARACTER SET utf32;
|
||||
INSERT INTO t1 VALUES (_koi8r 0xF2, _koi8r 0xF2), (X'2004',X'2004');
|
||||
SELECT hex(word) FROM t1 ORDER BY word;
|
||||
SELECT hex(word2) FROM t1 ORDER BY word2;
|
||||
DELETE FROM t1;
|
||||
|
||||
#
|
||||
# Check that real spaces are correctly trimmed.
|
||||
#
|
||||
|
||||
INSERT INTO t1 VALUES
|
||||
(X'000004200000002000000020',X'000004200000002000000020'),
|
||||
(X'000020040000002000000020',X'000020040000002000000020');
|
||||
SELECT hex(word) FROM t1 ORDER BY word;
|
||||
SELECT hex(word2) FROM t1 ORDER BY word2;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# Check LPAD/RPAD
|
||||
#
|
||||
SELECT hex(LPAD(_utf32 X'0420',10,_utf32 X'0421'));
|
||||
SELECT hex(LPAD(_utf32 X'0420',10,_utf32 X'0000042100000422'));
|
||||
SELECT hex(LPAD(_utf32 X'0420',10,_utf32 X'000004210000042200000423'));
|
||||
SELECT hex(LPAD(_utf32 X'000004200000042100000422000004230000042400000425000004260000042700000428000004290000042A0000042B',10,_utf32 X'000004210000042200000423'));
|
||||
|
||||
SELECT hex(RPAD(_utf32 X'0420',10,_utf32 X'0421'));
|
||||
SELECT hex(RPAD(_utf32 X'0420',10,_utf32 X'0000042100000422'));
|
||||
SELECT hex(RPAD(_utf32 X'0420',10,_utf32 X'000004210000042200000423'));
|
||||
SELECT hex(RPAD(_utf32 X'000004200000042100000422000004230000042400000425000004260000042700000428000004290000042A0000042B',10,_utf32 X'000004210000042200000423'));
|
||||
|
||||
CREATE TABLE t1 SELECT
|
||||
LPAD(_utf32 X'0420',10,_utf32 X'0421') l,
|
||||
RPAD(_utf32 X'0420',10,_utf32 X'0421') r;
|
||||
SHOW CREATE TABLE t1;
|
||||
select hex(l), hex(r) from t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
create table t1 (f1 char(30));
|
||||
insert into t1 values ("103000"), ("22720000"), ("3401200"), ("78000");
|
||||
select lpad(f1, 12, "-o-/") from t1;
|
||||
drop table t1;
|
||||
|
||||
######################################################
|
||||
#
|
||||
# Test of like
|
||||
#
|
||||
|
||||
SET NAMES latin1;
|
||||
SET character_set_connection=utf32;
|
||||
--source include/ctype_like.inc
|
||||
|
||||
SET NAMES utf8;
|
||||
SET character_set_connection=utf32;
|
||||
CREATE TABLE t1 (a VARCHAR(10) CHARACTER SET utf32);
|
||||
INSERT INTO t1 VALUES ('фыва'),('Фыва'),('фЫва'),('фыВа'),('фывА'),('ФЫВА');
|
||||
INSERT INTO t1 VALUES ('фывапролдж'),('Фывапролдж'),('фЫвапролдж'),('фыВапролдж');
|
||||
INSERT INTO t1 VALUES ('фывАпролдж'),('фываПролдж'),('фывапРолдж'),('фывапрОлдж');
|
||||
INSERT INTO t1 VALUES ('фывапроЛдж'),('фывапролДж'),('фывапролдЖ'),('ФЫВАПРОЛДЖ');
|
||||
SELECT * FROM t1 WHERE a LIKE '%фЫва%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE '%фЫв%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE 'фЫва%' ORDER BY BINARY a;
|
||||
SELECT * FROM t1 WHERE a LIKE 'фЫва%' COLLATE utf32_bin ORDER BY BINARY a;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (word varchar(64) NOT NULL, PRIMARY KEY (word))
|
||||
ENGINE=MyISAM CHARACTER SET utf32;
|
||||
INSERT INTO t1 (word) VALUES ("cat");
|
||||
SELECT * FROM t1 WHERE word LIKE "c%";
|
||||
SELECT * FROM t1 WHERE word LIKE "ca_";
|
||||
SELECT * FROM t1 WHERE word LIKE "cat";
|
||||
SELECT * FROM t1 WHERE word LIKE _utf32 x'0000006300000025'; # "c%"
|
||||
SELECT * FROM t1 WHERE word LIKE _utf32 x'00000063000000610000005F'; # "ca_"
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# Check that INSERT() works fine.
|
||||
# This invokes charpos() function.
|
||||
select insert(_utf32 0x000000610000006200000063,10,2,_utf32 0x000000640000006500000066);
|
||||
select insert(_utf32 0x000000610000006200000063,1,2,_utf32 0x000000640000006500000066);
|
||||
|
||||
#######################################################
|
||||
|
||||
#
|
||||
# Bug 1264
|
||||
#
|
||||
# Description:
|
||||
#
|
||||
# When using a ucs2 table in MySQL,
|
||||
# either with ucs2_general_ci or ucs2_bin collation,
|
||||
# words are returned in an incorrect order when using ORDER BY
|
||||
# on an _indexed_ CHAR or VARCHAR column. They are sorted with
|
||||
# the longest word *first* instead of last. I.E. The word "aardvark"
|
||||
# is in the results before the word "a".
|
||||
#
|
||||
# If there is no index for the column, the problem does not occur.
|
||||
#
|
||||
# Interestingly, if there is no second column, the words are returned
|
||||
# in the correct order.
|
||||
#
|
||||
# According to EXPLAIN, it looks like when the output includes columns that
|
||||
# are not part of the index sorted on, it does a filesort, which fails.
|
||||
# Using a straight index yields correct results.
|
||||
|
||||
SET NAMES latin1;
|
||||
|
||||
#
|
||||
# Two fields, index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word VARCHAR(64),
|
||||
bar INT(11) default 0,
|
||||
PRIMARY KEY (word))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf32
|
||||
COLLATE utf32_general_ci ;
|
||||
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a");
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY word;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
EXPLAIN SELECT word FROM t1 ORDER BY word;
|
||||
SELECT word FROM t1 ORDER by word;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# One field, index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word VARCHAR(64) ,
|
||||
PRIMARY KEY (word))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf32
|
||||
COLLATE utf32_general_ci;
|
||||
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a");
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY WORD;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
#
|
||||
# Two fields, no index
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
word TEXT,
|
||||
bar INT(11) AUTO_INCREMENT,
|
||||
PRIMARY KEY (bar))
|
||||
ENGINE=MyISAM
|
||||
CHARSET utf32
|
||||
COLLATE utf32_general_ci ;
|
||||
INSERT INTO t1 (word) VALUES ("aar");
|
||||
INSERT INTO t1 (word) VALUES ("a" );
|
||||
INSERT INTO t1 (word) VALUES ("aardvar");
|
||||
INSERT INTO t1 (word) VALUES ("aardvark");
|
||||
INSERT INTO t1 (word) VALUES ("aardvara");
|
||||
INSERT INTO t1 (word) VALUES ("aardvarz");
|
||||
EXPLAIN SELECT * FROM t1 ORDER BY word;
|
||||
SELECT * FROM t1 ORDER BY word;
|
||||
EXPLAIN SELECT word FROM t1 ORDER BY word;
|
||||
SELECT word FROM t1 ORDER BY word;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# END OF Bug 1264 test
|
||||
#
|
||||
########################################################
|
||||
|
||||
|
||||
#
|
||||
# Check alignment for from-binary-conversion with CAST and CONVERT
|
||||
#
|
||||
SELECT hex(cast(0xAA as char character set utf32));
|
||||
SELECT hex(convert(0xAA using utf32));
|
||||
|
||||
#
|
||||
# Check alignment for string types
|
||||
#
|
||||
CREATE TABLE t1 (a char(10) character set utf32);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a varchar(10) character set utf32);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a text character set utf32);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a mediumtext character set utf32);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a longtext character set utf32);
|
||||
INSERT INTO t1 VALUES (0x1),(0x11),(0x111),(0x1111),(0x11111);
|
||||
SELECT HEX(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
##
|
||||
## Bug #5024 Server crashes with queries on fields
|
||||
## with certain charset/collation settings
|
||||
##
|
||||
#
|
||||
#create table t1 (s1 char character set `ucs2` collate `ucs2_czech_ci`);
|
||||
#insert into t1 values ('0'),('1'),('2'),('a'),('b'),('c');
|
||||
#select s1 from t1 where s1 > 'a' order by s1;
|
||||
#drop table t1;
|
||||
|
||||
#
|
||||
# Bug #5081 : UCS2 fields are filled with '0x2020'
|
||||
# after extending field length
|
||||
#
|
||||
create table t1(a char(1)) default charset utf32;
|
||||
insert into t1 values ('a'),('b'),('c');
|
||||
alter table t1 modify a char(5);
|
||||
select a, hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Check prepare statement from an UTF32 string
|
||||
#
|
||||
set @ivar= 1234;
|
||||
set @str1 = 'select ?';
|
||||
set @str2 = convert(@str1 using utf32);
|
||||
prepare stmt1 from @str2;
|
||||
execute stmt1 using @ivar;
|
||||
|
||||
#
|
||||
# Check that utf32 works with ENUM and SET type
|
||||
#
|
||||
set names utf8;
|
||||
create table t1 (a enum('x','y','z') character set utf32);
|
||||
show create table t1;
|
||||
insert into t1 values ('x');
|
||||
insert into t1 values ('y');
|
||||
insert into t1 values ('z');
|
||||
select a, hex(a) from t1 order by a;
|
||||
alter table t1 change a a enum('x','y','z','d','e','ä','ö','ü') character set utf32;
|
||||
show create table t1;
|
||||
insert into t1 values ('D');
|
||||
insert into t1 values ('E ');
|
||||
insert into t1 values ('ä');
|
||||
insert into t1 values ('ö');
|
||||
insert into t1 values ('ü');
|
||||
select a, hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
create table t1 (a set ('x','y','z','ä','ö','ü') character set utf32);
|
||||
show create table t1;
|
||||
insert into t1 values ('x');
|
||||
insert into t1 values ('y');
|
||||
insert into t1 values ('z');
|
||||
insert into t1 values ('x,y');
|
||||
insert into t1 values ('x,y,z,ä,ö,ü');
|
||||
select a, hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#7302 UCS2 data in ENUM fields get truncated when new column is added
|
||||
#
|
||||
create table t1(a enum('a','b','c')) default character set utf32;
|
||||
insert into t1 values('a'),('b'),('c');
|
||||
alter table t1 add b char(1);
|
||||
show warnings;
|
||||
select * from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
SET NAMES latin1;
|
||||
SET collation_connection='utf32_general_ci';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
SET NAMES latin1;
|
||||
SET collation_connection='utf32_bin';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
|
||||
#
|
||||
# Bug#10344 Some string functions fail for UCS2
|
||||
#
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,1));
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,2));
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,3));
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,-1));
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,-2));
|
||||
select hex(substr(_utf32 0x000000e4000000e500000068,-3));
|
||||
|
||||
#SET NAMES latin1;
|
||||
#
|
||||
# Bug#8235
|
||||
#
|
||||
# This bug also helped to find another problem that
|
||||
# INSERT of a UCS2 string containing a negative number
|
||||
# into a unsigned int column didn't produce warnings.
|
||||
# This test covers both problems.
|
||||
#
|
||||
#SET collation_connection='ucs2_swedish_ci';
|
||||
#CREATE TABLE t1 (Field1 int(10) default '0');
|
||||
## no warnings, negative numbers are allowed
|
||||
#INSERT INTO t1 VALUES ('-1');
|
||||
#SELECT * FROM t1;
|
||||
#DROP TABLE t1;
|
||||
#CREATE TABLE t1 (Field1 int(10) unsigned default '0');
|
||||
## this should generate a "Data truncated" warning
|
||||
#INSERT INTO t1 VALUES ('-1');
|
||||
#DROP TABLE t1;
|
||||
#SET NAMES latin1;
|
||||
|
||||
#
|
||||
##
|
||||
## Bug#18691 Converting number to UNICODE string returns invalid result
|
||||
##
|
||||
#SELECT CONVERT(103, CHAR(50) UNICODE);
|
||||
#SELECT CONVERT(103.0, CHAR(50) UNICODE);
|
||||
#SELECT CONVERT(-103, CHAR(50) UNICODE);
|
||||
#SELECT CONVERT(-103.0, CHAR(50) UNICODE);
|
||||
|
||||
#
|
||||
# Bug#9557 MyISAM utf8 table crash
|
||||
#
|
||||
CREATE TABLE t1 (
|
||||
a varchar(250) NOT NULL default '',
|
||||
KEY a (a)
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=utf32 COLLATE utf32_general_ci;
|
||||
insert into t1 values (0x803d);
|
||||
insert into t1 values (0x005b);
|
||||
select hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
##
|
||||
## Bug #14583 Bug on query using a LIKE on indexed field with ucs2_bin collation
|
||||
##
|
||||
#--disable_warnings
|
||||
#create table t1(f1 varchar(5) CHARACTER SET utf32 COLLATE utf32_bin NOT NULL) engine=InnoDB;
|
||||
#--enable_warnings
|
||||
#insert into t1 values('a');
|
||||
#create index t1f1 on t1(f1);
|
||||
#select f1 from t1 where f1 like 'a%';
|
||||
#drop table t1;
|
||||
|
||||
#
|
||||
# Bug#9442 Set parameter make query fail if column character set is UCS2
|
||||
#
|
||||
create table t1 (utext varchar(20) character set utf32);
|
||||
insert into t1 values ("lily");
|
||||
insert into t1 values ("river");
|
||||
prepare stmt from 'select utext from t1 where utext like ?';
|
||||
set @param1='%%';
|
||||
execute stmt using @param1;
|
||||
execute stmt using @param1;
|
||||
select utext from t1 where utext like '%%';
|
||||
drop table t1;
|
||||
deallocate prepare stmt;
|
||||
|
||||
#
|
||||
# Bug#22052 Trailing spaces are not removed from UNICODE fields in an index
|
||||
#
|
||||
create table t1 (
|
||||
a char(10) character set utf32 not null,
|
||||
index a (a)
|
||||
) engine=myisam;
|
||||
insert into t1 values (repeat(0x0000201f, 10));
|
||||
insert into t1 values (repeat(0x00002020, 10));
|
||||
insert into t1 values (repeat(0x00002021, 10));
|
||||
# make sure "index read" is used
|
||||
explain select hex(a) from t1 order by a;
|
||||
select hex(a) from t1 order by a;
|
||||
alter table t1 drop index a;
|
||||
select hex(a) from t1 order by a;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug #20076: server crashes for a query with GROUP BY if MIN/MAX aggregation
|
||||
# over a 'ucs2' field uses a temporary table
|
||||
#
|
||||
#CREATE TABLE t1 (id int, s char(5) CHARACTER SET ucs2 COLLATE ucs2_unicode_ci);
|
||||
#INSERT INTO t1 VALUES (1, 'ZZZZZ'), (1, 'ZZZ'), (2, 'ZZZ'), (2, 'ZZZZZ');
|
||||
#SELECT id, MIN(s) FROM t1 GROUP BY id;
|
||||
#DROP TABLE t1;
|
||||
|
||||
##
|
||||
## Bug #20536: md5() with GROUP BY and UCS2 return different results on myisam/innodb
|
||||
##
|
||||
#
|
||||
#--disable_warnings
|
||||
#drop table if exists bug20536;
|
||||
#--enable_warnings
|
||||
#
|
||||
#set names latin1;
|
||||
#create table bug20536 (id bigint not null auto_increment primary key, name
|
||||
#varchar(255) character set ucs2 not null);
|
||||
#insert into `bug20536` (`id`,`name`) values (1, _latin1 x'7465737431'), (2, "'test\\_2'");
|
||||
#select md5(name) from bug20536;
|
||||
#select sha1(name) from bug20536;
|
||||
#select make_set(3, name, upper(name)) from bug20536;
|
||||
#select export_set(5, name, upper(name)) from bug20536;
|
||||
#select export_set(5, name, upper(name), ",", 5) from bug20536;
|
||||
|
||||
#
|
||||
# Bug #20108: corrupted default enum value for a ucs2 field
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (
|
||||
status enum('active','passive') character set utf32 collate utf32_general_ci
|
||||
NOT NULL default 'passive'
|
||||
);
|
||||
SHOW CREATE TABLE t1;
|
||||
ALTER TABLE t1 ADD a int NOT NULL AFTER status;
|
||||
SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
#CREATE TABLE t2 (
|
||||
# status enum('active','passive') collate ucs2_turkish_ci
|
||||
# NOT NULL default 'passive'
|
||||
#);
|
||||
#SHOW CREATE TABLE t2;
|
||||
#ALTER TABLE t2 ADD a int NOT NULL AFTER status;
|
||||
#DROP TABLE t2;
|
||||
|
||||
|
||||
## Some broken functions: add these tests just to document current behavior.
|
||||
#
|
||||
## PASSWORD and OLD_PASSWORD don't work with UCS2 strings, but to fix it would
|
||||
## not be backwards compatible in all cases, so it's best to leave it alone
|
||||
#select password(name) from bug20536;
|
||||
#select old_password(name) from bug20536;
|
||||
#
|
||||
## Disable test case as encrypt relies on 'crypt' function.
|
||||
## "decrypt" is noramlly tested in func_crypt.test which have a
|
||||
## "have_crypt.inc" test
|
||||
#--disable_parsing
|
||||
## ENCRYPT relies on OS function crypt() which takes a NUL-terminated string; it
|
||||
## doesn't return good results for strings with embedded 0 bytes. It won't be
|
||||
## fixed unless we choose to re-implement the crypt() function ourselves to take
|
||||
## an extra size_t string_length argument.
|
||||
#select encrypt(name, 'SALT') from bug20536;
|
||||
#--enable_parsing
|
||||
#
|
||||
## QUOTE doesn't work with UCS2 data. It would require a total rewrite
|
||||
## of Item_func_quote::val_str(), which isn't worthwhile until UCS2 is
|
||||
## supported fully as a client character set.
|
||||
#select quote(name) from bug20536;
|
||||
#
|
||||
#drop table bug20536;
|
||||
#
|
||||
--echo End of 4.1 tests
|
||||
|
||||
|
||||
#
|
||||
# Conversion from an UTF32 string to a decimal column
|
||||
#
|
||||
CREATE TABLE t1 (a varchar(64) character set utf32, b decimal(10,3));
|
||||
INSERT INTO t1 VALUES ("1.1", 0), ("2.1", 0);
|
||||
update t1 set b=a;
|
||||
SELECT *, hex(a) FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# Bug#9442 Set parameter make query fail if column character set is UCS2
|
||||
#
|
||||
create table t1 (utext varchar(20) character set utf32);
|
||||
insert into t1 values ("lily");
|
||||
insert into t1 values ("river");
|
||||
prepare stmt from 'select utext from t1 where utext like ?';
|
||||
set @param1='%%';
|
||||
execute stmt using @param1;
|
||||
execute stmt using @param1;
|
||||
select utext from t1 where utext like '%%';
|
||||
drop table t1;
|
||||
deallocate prepare stmt;
|
||||
|
||||
#
|
||||
# Bug#22638 SOUNDEX broken for international characters
|
||||
#
|
||||
set names latin1;
|
||||
set character_set_connection=utf32;
|
||||
select soundex(''),soundex('he'),soundex('hello all folks'),soundex('#3556 in bugdb');
|
||||
select hex(soundex('')),hex(soundex('he')),hex(soundex('hello all folks')),hex(soundex('#3556 in bugdb'));
|
||||
select 'mood' sounds like 'mud';
|
||||
# Cyrillic A, BE, VE
|
||||
select hex(soundex(_utf32 0x000004100000041100000412));
|
||||
# Make sure that "U+00BF INVERTED QUESTION MARK" is not considered as letter
|
||||
select hex(soundex(_utf32 0x000000BF000000C0));
|
||||
set names latin1;
|
||||
|
||||
#
|
||||
# Bug #14290: character_maximum_length for text fields
|
||||
#
|
||||
create table t1(a blob, b text charset utf32);
|
||||
select data_type, character_octet_length, character_maximum_length
|
||||
from information_schema.columns where table_name='t1';
|
||||
drop table t1;
|
||||
|
||||
|
||||
set names latin1;
|
||||
set collation_connection=utf32_general_ci;
|
||||
#
|
||||
# Testing cs->coll->instr()
|
||||
#
|
||||
select position('bb' in 'abba');
|
||||
|
||||
#
|
||||
# Testing cs->coll->hash_sort()
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf32) engine=heap;
|
||||
insert into t1 values ('a'),('A'),('b'),('B');
|
||||
select * from t1 where a='a' order by binary a;
|
||||
select hex(min(binary a)),count(*) from t1 group by a;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->numchars()
|
||||
#
|
||||
select char_length('abcd'), octet_length('abcd');
|
||||
|
||||
#
|
||||
# Testing cs->cset->charpos()
|
||||
#
|
||||
select left('abcd',2);
|
||||
|
||||
#
|
||||
# Testing cs->cset->well_formed_length()
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf32);
|
||||
insert into t1 values (_utf32 0x0010FFFF);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf32 0x00110000);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf32 0x00110101);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf32 0x01000101);
|
||||
--error ER_INVALID_CHARACTER_STRING
|
||||
insert into t1 values (_utf32 0x11000101);
|
||||
select hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#32914 Character sets: illegal characters in utf8 and utf32 columns
|
||||
#
|
||||
create table t1 (utf32 varchar(2) character set utf32);
|
||||
--echo Wrong character with pad
|
||||
insert into t1 values (0x110000);
|
||||
--echo Wrong chsaracter without pad
|
||||
insert into t1 values (0x00110000);
|
||||
--echo Wrong character with pad followed by another wrong character
|
||||
insert into t1 values (0x11000000110000);
|
||||
--echo Good character with pad followed by bad character
|
||||
insert into t1 values (0x10000000110000);
|
||||
--echo Good character without pad followed by bad character
|
||||
insert into t1 values (0x0010000000110000);
|
||||
--echo Wrong character with the second byte higher than 0x10
|
||||
insert into t1 values (0x00800037);
|
||||
--echo Wrong character with pad with the second byte higher than 0x10
|
||||
insert into t1 values (0x00800037);
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#32394 Character sets: crash if comparison with 0xfffd
|
||||
#
|
||||
select _utf32'a' collate utf32_general_ci = 0xfffd;
|
||||
select hex(concat(_utf32 0x0410 collate utf32_general_ci, 0x61));
|
||||
create table t1 (s1 varchar(5) character set utf32);
|
||||
insert into t1 values (0xfffd);
|
||||
select case when s1 = 0xfffd then 1 else 0 end from t1;
|
||||
select hex(s1) from t1 where s1 = 0xfffd;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->lengthsp()
|
||||
#
|
||||
create table t1 (a char(10)) character set utf32;
|
||||
insert into t1 values ('a ');
|
||||
select hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->caseup() and cs->cset->casedn()
|
||||
#
|
||||
select upper('abcd'), lower('ABCD');
|
||||
|
||||
#
|
||||
# TODO: str_to_datetime() is broken and doesn't work with ucs2 and utf32
|
||||
# Testing cs->cset->snprintf()
|
||||
#
|
||||
#create table t1 (a date);
|
||||
#insert into t1 values ('2007-09-16');
|
||||
#select * from t1;
|
||||
#drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->l10tostr
|
||||
# !!! Not used in the code
|
||||
|
||||
#
|
||||
# Testing cs->cset->ll10tostr
|
||||
#
|
||||
create table t1 (a varchar(10) character set utf32);
|
||||
insert into t1 values (123456);
|
||||
select a, hex(a) from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->fill
|
||||
# SOUNDEX fills strings with DIGIT ZERO up to four characters
|
||||
select hex(soundex('a'));
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntol
|
||||
# !!! Not used in the code
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoul
|
||||
#
|
||||
create table t1 (a enum ('a','b','c')) character set utf32;
|
||||
insert into t1 values ('1');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoll and cs->cset->strntoull
|
||||
#
|
||||
set names latin1;
|
||||
select hex(conv(convert('123' using utf32), -10, 16));
|
||||
select hex(conv(convert('123' using utf32), 10, 16));
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntod
|
||||
#
|
||||
set names latin1;
|
||||
set character_set_connection=utf32;
|
||||
select 1.1 + '1.2';
|
||||
select 1.1 + '1.2xxx';
|
||||
|
||||
# Testing strntoll10_utf32
|
||||
# Testing cs->cset->strtoll10
|
||||
select left('aaa','1');
|
||||
|
||||
#
|
||||
# Testing cs->cset->strntoull10rnd
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values ('-1234.1e2');
|
||||
insert into t1 values ('-1234.1e2xxxx');
|
||||
insert into t1 values ('-1234.1e2 ');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing cs->cset->scan
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values ('1 ');
|
||||
insert into t1 values ('1 x');
|
||||
select * from t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing auto-conversion to TEXT
|
||||
#
|
||||
create table t1 (a varchar(17000) character set utf32);
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Testing that maximim possible key length is 1332 bytes
|
||||
#
|
||||
create table t1 (a varchar(250) character set utf32 primary key);
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
--error ER_TOO_LONG_KEY
|
||||
create table t1 (a varchar(334) character set utf32 primary key);
|
||||
|
||||
#
|
||||
# Testing mi_check with long key values
|
||||
#
|
||||
create table t1 (a varchar(333) character set utf32, key(a));
|
||||
insert into t1 values (repeat('a',333)), (repeat('b',333));
|
||||
flush tables;
|
||||
check table t1;
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Test how character set works with date/time
|
||||
#
|
||||
SET collation_connection=utf32_general_ci;
|
||||
--source include/ctype_datetime.inc
|
||||
SET NAMES latin1;
|
||||
|
||||
#
|
||||
# Test basic regex functionality
|
||||
#
|
||||
set collation_connection=utf32_general_ci;
|
||||
--source include/ctype_regex.inc
|
||||
set names latin1;
|
||||
|
||||
|
||||
# TODO: add tests for all engines
|
||||
|
||||
#
|
||||
# Bug #36418 Character sets: crash if char(256 using utf32)
|
||||
#
|
||||
select hex(char(0x01 using utf32));
|
||||
select hex(char(0x0102 using utf32));
|
||||
select hex(char(0x010203 using utf32));
|
||||
select hex(char(0x01020304 using utf32));
|
||||
create table t1 (s1 varchar(1) character set utf32, s2 text character set utf32);
|
||||
create index i on t1 (s1);
|
||||
insert into t1 values (char(256 using utf32), char(256 using utf32));
|
||||
select hex(s1), hex(s2) from t1;
|
||||
drop table t1;
|
||||
|
||||
|
||||
#
|
||||
# Bug#33073 Character sets: ordering fails with utf32
|
||||
#
|
||||
SET collation_connection=utf32_general_ci;
|
||||
CREATE TABLE t1 AS SELECT repeat('a',2) as s1 LIMIT 0;
|
||||
SHOW CREATE TABLE t1;
|
||||
INSERT INTO t1 VALUES ('ab'),('AE'),('ab'),('AE');
|
||||
SELECT * FROM t1 ORDER BY s1;
|
||||
SET max_sort_length=4;
|
||||
SELECT * FROM t1 ORDER BY s1;
|
||||
DROP TABLE t1;
|
||||
SET max_sort_length=DEFAULT;
|
||||
SET NAMES latin1;
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
291
mysql-test/t/ctype_utf32_uca.test
Normal file
291
mysql-test/t/ctype_utf32_uca.test
Normal file
@ -0,0 +1,291 @@
|
||||
-- source include/have_ucs2.inc
|
||||
-- source include/have_utf32.inc
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
--enable_warnings
|
||||
|
||||
--echo #
|
||||
--echo # Start of 5.5 tests
|
||||
--echo #
|
||||
|
||||
set names utf8;
|
||||
set collation_connection=utf32_unicode_ci;
|
||||
select hex('a'), hex('a ');
|
||||
-- source include/endspace.inc
|
||||
|
||||
#
|
||||
# Bug #6787 LIKE not working properly with _ and utf8 data
|
||||
#
|
||||
select 'c' like '\_' as want0;
|
||||
|
||||
#
|
||||
# Bug #5679 utf8_unicode_ci LIKE--trailing % doesn't equal zero characters
|
||||
#
|
||||
CREATE TABLE t (
|
||||
c char(20) NOT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARACTER SET utf32 COLLATE=utf32_unicode_ci;
|
||||
INSERT INTO t VALUES ('a'),('ab'),('aba');
|
||||
ALTER TABLE t ADD INDEX (c);
|
||||
SELECT c FROM t WHERE c LIKE 'a%';
|
||||
DROP TABLE t;
|
||||
|
||||
|
||||
create table t1 (c1 char(10) character set utf32 collate utf32_bin);
|
||||
|
||||
#
|
||||
# Basic Latin
|
||||
#
|
||||
insert into t1 values ('A'),('a');
|
||||
insert into t1 values ('B'),('b');
|
||||
insert into t1 values ('C'),('c');
|
||||
insert into t1 values ('D'),('d');
|
||||
insert into t1 values ('E'),('e');
|
||||
insert into t1 values ('F'),('f');
|
||||
insert into t1 values ('G'),('g');
|
||||
insert into t1 values ('H'),('h');
|
||||
insert into t1 values ('I'),('i');
|
||||
insert into t1 values ('J'),('j');
|
||||
insert into t1 values ('K'),('k');
|
||||
insert into t1 values ('L'),('l');
|
||||
insert into t1 values ('M'),('m');
|
||||
insert into t1 values ('N'),('n');
|
||||
insert into t1 values ('O'),('o');
|
||||
insert into t1 values ('P'),('p');
|
||||
insert into t1 values ('Q'),('q');
|
||||
insert into t1 values ('R'),('r');
|
||||
insert into t1 values ('S'),('s');
|
||||
insert into t1 values ('T'),('t');
|
||||
insert into t1 values ('U'),('u');
|
||||
insert into t1 values ('V'),('v');
|
||||
insert into t1 values ('W'),('w');
|
||||
insert into t1 values ('X'),('x');
|
||||
insert into t1 values ('Y'),('y');
|
||||
insert into t1 values ('Z'),('z');
|
||||
|
||||
#
|
||||
# Latin1 suppliment
|
||||
#
|
||||
insert into t1 values (_ucs2 0x00e0),(_ucs2 0x00c0);
|
||||
insert into t1 values (_ucs2 0x00e1),(_ucs2 0x00c1);
|
||||
insert into t1 values (_ucs2 0x00e2),(_ucs2 0x00c2);
|
||||
insert into t1 values (_ucs2 0x00e3),(_ucs2 0x00c3);
|
||||
insert into t1 values (_ucs2 0x00e4),(_ucs2 0x00c4);
|
||||
insert into t1 values (_ucs2 0x00e5),(_ucs2 0x00c5);
|
||||
insert into t1 values (_ucs2 0x00e6),(_ucs2 0x00c6);
|
||||
insert into t1 values (_ucs2 0x00e7),(_ucs2 0x00c7);
|
||||
insert into t1 values (_ucs2 0x00e8),(_ucs2 0x00c8);
|
||||
insert into t1 values (_ucs2 0x00e9),(_ucs2 0x00c9);
|
||||
insert into t1 values (_ucs2 0x00ea),(_ucs2 0x00ca);
|
||||
insert into t1 values (_ucs2 0x00eb),(_ucs2 0x00cb);
|
||||
insert into t1 values (_ucs2 0x00ec),(_ucs2 0x00cc);
|
||||
insert into t1 values (_ucs2 0x00ed),(_ucs2 0x00cd);
|
||||
insert into t1 values (_ucs2 0x00ee),(_ucs2 0x00ce);
|
||||
insert into t1 values (_ucs2 0x00ef),(_ucs2 0x00cf);
|
||||
|
||||
insert into t1 values (_ucs2 0x00f0),(_ucs2 0x00d0);
|
||||
insert into t1 values (_ucs2 0x00f1),(_ucs2 0x00d1);
|
||||
insert into t1 values (_ucs2 0x00f2),(_ucs2 0x00d2);
|
||||
insert into t1 values (_ucs2 0x00f3),(_ucs2 0x00d3);
|
||||
insert into t1 values (_ucs2 0x00f4),(_ucs2 0x00d4);
|
||||
insert into t1 values (_ucs2 0x00f5),(_ucs2 0x00d5);
|
||||
insert into t1 values (_ucs2 0x00f6),(_ucs2 0x00d6);
|
||||
insert into t1 values (_ucs2 0x00f7),(_ucs2 0x00d7);
|
||||
insert into t1 values (_ucs2 0x00f8),(_ucs2 0x00d8);
|
||||
insert into t1 values (_ucs2 0x00f9),(_ucs2 0x00d9);
|
||||
insert into t1 values (_ucs2 0x00fa),(_ucs2 0x00da);
|
||||
insert into t1 values (_ucs2 0x00fb),(_ucs2 0x00db);
|
||||
insert into t1 values (_ucs2 0x00fc),(_ucs2 0x00dc);
|
||||
insert into t1 values (_ucs2 0x00fd),(_ucs2 0x00dd);
|
||||
insert into t1 values (_ucs2 0x00fe),(_ucs2 0x00de);
|
||||
insert into t1 values (_ucs2 0x00ff),(_ucs2 0x00df);
|
||||
|
||||
#
|
||||
# Latin extended-A, 0100-017F
|
||||
#
|
||||
insert into t1 values (_ucs2 0x0100),(_ucs2 0x0101),(_ucs2 0x0102),(_ucs2 0x0103);
|
||||
insert into t1 values (_ucs2 0x0104),(_ucs2 0x0105),(_ucs2 0x0106),(_ucs2 0x0107);
|
||||
insert into t1 values (_ucs2 0x0108),(_ucs2 0x0109),(_ucs2 0x010a),(_ucs2 0x010b);
|
||||
insert into t1 values (_ucs2 0x010c),(_ucs2 0x010d),(_ucs2 0x010e),(_ucs2 0x010f);
|
||||
insert into t1 values (_ucs2 0x0110),(_ucs2 0x0111),(_ucs2 0x0112),(_ucs2 0x0113);
|
||||
insert into t1 values (_ucs2 0x0114),(_ucs2 0x0115),(_ucs2 0x0116),(_ucs2 0x0117);
|
||||
insert into t1 values (_ucs2 0x0118),(_ucs2 0x0119),(_ucs2 0x011a),(_ucs2 0x011b);
|
||||
insert into t1 values (_ucs2 0x011c),(_ucs2 0x011d),(_ucs2 0x011e),(_ucs2 0x011f);
|
||||
insert into t1 values (_ucs2 0x0120),(_ucs2 0x0121),(_ucs2 0x0122),(_ucs2 0x0123);
|
||||
insert into t1 values (_ucs2 0x0124),(_ucs2 0x0125),(_ucs2 0x0126),(_ucs2 0x0127);
|
||||
insert into t1 values (_ucs2 0x0128),(_ucs2 0x0129),(_ucs2 0x012a),(_ucs2 0x012b);
|
||||
insert into t1 values (_ucs2 0x012c),(_ucs2 0x012d),(_ucs2 0x012e),(_ucs2 0x012f);
|
||||
insert into t1 values (_ucs2 0x0130),(_ucs2 0x0131),(_ucs2 0x0132),(_ucs2 0x0133);
|
||||
insert into t1 values (_ucs2 0x0134),(_ucs2 0x0135),(_ucs2 0x0136),(_ucs2 0x0137);
|
||||
insert into t1 values (_ucs2 0x0138),(_ucs2 0x0139),(_ucs2 0x013a),(_ucs2 0x013b);
|
||||
insert into t1 values (_ucs2 0x013c),(_ucs2 0x013d),(_ucs2 0x013e),(_ucs2 0x013f);
|
||||
insert into t1 values (_ucs2 0x0140),(_ucs2 0x0141),(_ucs2 0x0142),(_ucs2 0x0143);
|
||||
insert into t1 values (_ucs2 0x0144),(_ucs2 0x0145),(_ucs2 0x0146),(_ucs2 0x0147);
|
||||
insert into t1 values (_ucs2 0x0148),(_ucs2 0x0149),(_ucs2 0x014a),(_ucs2 0x014b);
|
||||
insert into t1 values (_ucs2 0x014c),(_ucs2 0x014d),(_ucs2 0x014e),(_ucs2 0x014f);
|
||||
insert into t1 values (_ucs2 0x0150),(_ucs2 0x0151),(_ucs2 0x0152),(_ucs2 0x0153);
|
||||
insert into t1 values (_ucs2 0x0154),(_ucs2 0x0155),(_ucs2 0x0156),(_ucs2 0x0157);
|
||||
insert into t1 values (_ucs2 0x0158),(_ucs2 0x0159),(_ucs2 0x015a),(_ucs2 0x015b);
|
||||
insert into t1 values (_ucs2 0x015c),(_ucs2 0x015d),(_ucs2 0x015e),(_ucs2 0x015f);
|
||||
insert into t1 values (_ucs2 0x0160),(_ucs2 0x0161),(_ucs2 0x0162),(_ucs2 0x0163);
|
||||
insert into t1 values (_ucs2 0x0164),(_ucs2 0x0165),(_ucs2 0x0166),(_ucs2 0x0167);
|
||||
insert into t1 values (_ucs2 0x0168),(_ucs2 0x0169),(_ucs2 0x016a),(_ucs2 0x016b);
|
||||
insert into t1 values (_ucs2 0x016c),(_ucs2 0x016d),(_ucs2 0x016e),(_ucs2 0x016f);
|
||||
insert into t1 values (_ucs2 0x0170),(_ucs2 0x0171),(_ucs2 0x0172),(_ucs2 0x0173);
|
||||
insert into t1 values (_ucs2 0x0174),(_ucs2 0x0175),(_ucs2 0x0176),(_ucs2 0x0177);
|
||||
insert into t1 values (_ucs2 0x0178),(_ucs2 0x0179),(_ucs2 0x017a),(_ucs2 0x017b);
|
||||
insert into t1 values (_ucs2 0x017c),(_ucs2 0x017d),(_ucs2 0x017e),(_ucs2 0x017f);
|
||||
|
||||
#
|
||||
# Latin extended-B, 0180-024F
|
||||
#
|
||||
insert into t1 values (_ucs2 0x0180),(_ucs2 0x0181),(_ucs2 0x0182),(_ucs2 0x0183);
|
||||
insert into t1 values (_ucs2 0x0184),(_ucs2 0x0185),(_ucs2 0x0186),(_ucs2 0x0187);
|
||||
insert into t1 values (_ucs2 0x0188),(_ucs2 0x0189),(_ucs2 0x018a),(_ucs2 0x018b);
|
||||
insert into t1 values (_ucs2 0x018c),(_ucs2 0x018d),(_ucs2 0x018e),(_ucs2 0x018f);
|
||||
insert into t1 values (_ucs2 0x0190),(_ucs2 0x0191),(_ucs2 0x0192),(_ucs2 0x0193);
|
||||
insert into t1 values (_ucs2 0x0194),(_ucs2 0x0195),(_ucs2 0x0196),(_ucs2 0x0197);
|
||||
insert into t1 values (_ucs2 0x0198),(_ucs2 0x0199),(_ucs2 0x019a),(_ucs2 0x019b);
|
||||
insert into t1 values (_ucs2 0x019c),(_ucs2 0x019d),(_ucs2 0x019e),(_ucs2 0x019f);
|
||||
insert into t1 values (_ucs2 0x01a0),(_ucs2 0x01a1),(_ucs2 0x01a2),(_ucs2 0x01a3);
|
||||
insert into t1 values (_ucs2 0x01a4),(_ucs2 0x01a5),(_ucs2 0x01a6),(_ucs2 0x01a7);
|
||||
insert into t1 values (_ucs2 0x01a8),(_ucs2 0x01a9),(_ucs2 0x01aa),(_ucs2 0x01ab);
|
||||
insert into t1 values (_ucs2 0x01ac),(_ucs2 0x01ad),(_ucs2 0x01ae),(_ucs2 0x01af);
|
||||
insert into t1 values (_ucs2 0x01b0),(_ucs2 0x01b1),(_ucs2 0x01b2),(_ucs2 0x01b3);
|
||||
insert into t1 values (_ucs2 0x01b4),(_ucs2 0x01b5),(_ucs2 0x01b6),(_ucs2 0x01b7);
|
||||
insert into t1 values (_ucs2 0x01b8),(_ucs2 0x01b9),(_ucs2 0x01ba),(_ucs2 0x01bb);
|
||||
insert into t1 values (_ucs2 0x01bc),(_ucs2 0x01bd),(_ucs2 0x01be),(_ucs2 0x01bf);
|
||||
insert into t1 values (_ucs2 0x01c0),(_ucs2 0x01c1),(_ucs2 0x01c2),(_ucs2 0x01c3);
|
||||
insert into t1 values (_ucs2 0x01c4),(_ucs2 0x01c5),(_ucs2 0x01c6),(_ucs2 0x01c7);
|
||||
insert into t1 values (_ucs2 0x01c8),(_ucs2 0x01c9),(_ucs2 0x01ca),(_ucs2 0x01cb);
|
||||
insert into t1 values (_ucs2 0x01cc),(_ucs2 0x01cd),(_ucs2 0x01ce),(_ucs2 0x01cf);
|
||||
insert into t1 values (_ucs2 0x01d0),(_ucs2 0x01d1),(_ucs2 0x01d2),(_ucs2 0x01d3);
|
||||
insert into t1 values (_ucs2 0x01d4),(_ucs2 0x01d5),(_ucs2 0x01d6),(_ucs2 0x01d7);
|
||||
insert into t1 values (_ucs2 0x01d8),(_ucs2 0x01d9),(_ucs2 0x01da),(_ucs2 0x01db);
|
||||
insert into t1 values (_ucs2 0x01dc),(_ucs2 0x01dd),(_ucs2 0x01de),(_ucs2 0x01df);
|
||||
insert into t1 values (_ucs2 0x01e0),(_ucs2 0x01e1),(_ucs2 0x01e2),(_ucs2 0x01e3);
|
||||
insert into t1 values (_ucs2 0x01e4),(_ucs2 0x01e5),(_ucs2 0x01e6),(_ucs2 0x01e7);
|
||||
insert into t1 values (_ucs2 0x01e8),(_ucs2 0x01e9),(_ucs2 0x01ea),(_ucs2 0x01eb);
|
||||
insert into t1 values (_ucs2 0x01ec),(_ucs2 0x01ed),(_ucs2 0x01ee),(_ucs2 0x01ef);
|
||||
insert into t1 values (_ucs2 0x01f0),(_ucs2 0x01f1),(_ucs2 0x01f2),(_ucs2 0x01f3);
|
||||
insert into t1 values (_ucs2 0x01f4),(_ucs2 0x01f5),(_ucs2 0x01f6),(_ucs2 0x01f7);
|
||||
insert into t1 values (_ucs2 0x01f8),(_ucs2 0x01f9),(_ucs2 0x01fa),(_ucs2 0x01fb);
|
||||
insert into t1 values (_ucs2 0x01fc),(_ucs2 0x01fd),(_ucs2 0x01fe),(_ucs2 0x01ff);
|
||||
|
||||
|
||||
insert into t1 values ('AA'),('Aa'),('aa'),('aA');
|
||||
insert into t1 values ('CH'),('Ch'),('ch'),('cH');
|
||||
insert into t1 values ('DZ'),('Dz'),('dz'),('dZ');
|
||||
insert into t1 values ('IJ'),('Ij'),('ij'),('iJ');
|
||||
insert into t1 values ('LJ'),('Lj'),('lj'),('lJ');
|
||||
insert into t1 values ('LL'),('Ll'),('ll'),('lL');
|
||||
insert into t1 values ('NJ'),('Nj'),('nj'),('nJ');
|
||||
insert into t1 values ('OE'),('Oe'),('oe'),('oE');
|
||||
insert into t1 values ('SS'),('Ss'),('ss'),('sS');
|
||||
insert into t1 values ('RR'),('Rr'),('rr'),('rR');
|
||||
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_unicode_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_icelandic_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_latvian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_romanian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_slovenian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_polish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_estonian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_spanish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_swedish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_turkish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_czech_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_danish_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_lithuanian_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_slovak_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_spanish2_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_roman_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_esperanto_ci;
|
||||
select group_concat(c1 order by binary c1 separator '') from t1 group by c1 collate utf32_hungarian_ci;
|
||||
|
||||
drop table t1;
|
||||
|
||||
#
|
||||
# Bug#5324
|
||||
#
|
||||
SET NAMES utf8;
|
||||
#test1
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf32 COLLATE utf32_general_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (_ucs2 0x039C03C903B403B11F770308);
|
||||
#Check one row
|
||||
SELECT * FROM t1 WHERE c LIKE _utf32 0x0000039C00000025 COLLATE utf32_general_ci;
|
||||
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x039C03C903B4 USING utf8));
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE _utf32 0x0000039C00000025
|
||||
COLLATE utf32_general_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
#test2
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf32 COLLATE utf32_unicode_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (_ucs2 0x039C03C903B403B11F770308);
|
||||
#Check one row
|
||||
SELECT * FROM t1 WHERE c LIKE _utf32 0x0000039C00000025 COLLATE utf32_unicode_ci;
|
||||
INSERT INTO t1 VALUES (_ucs2 0x039C03C903B4);
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE _utf32 0x0000039C00000025
|
||||
COLLATE utf32_unicode_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
#test 3
|
||||
CREATE TABLE t1 (c varchar(200) CHARACTER SET utf32 COLLATE utf32_unicode_ci NOT NULL, INDEX (c));
|
||||
INSERT INTO t1 VALUES (_ucs2 0x039C03C903B403B11F770308);
|
||||
#Check one row row
|
||||
SELECT * FROM t1 WHERE c LIKE CONVERT(_ucs2 0x039C0025 USING utf32) COLLATE utf32_unicode_ci;
|
||||
INSERT INTO t1 VALUES (CONVERT(_ucs2 0x039C03C903B4 USING utf8));
|
||||
#Check two rows
|
||||
SELECT * FROM t1 WHERE c LIKE CONVERT(_ucs2 0x039C0025 USING utf32)
|
||||
COLLATE utf32_unicode_ci ORDER BY c;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
SET NAMES utf8;
|
||||
SET @test_character_set='utf32';
|
||||
SET @test_collation='utf32_swedish_ci';
|
||||
-- source include/ctype_common.inc
|
||||
|
||||
|
||||
SET collation_connection='utf32_unicode_ci';
|
||||
-- source include/ctype_filesort.inc
|
||||
-- source include/ctype_like_escape.inc
|
||||
|
||||
--echo End of 4.1 tests
|
||||
|
||||
#
|
||||
# Check UPPER/LOWER changing length
|
||||
#
|
||||
# Result shorter than argument
|
||||
CREATE TABLE t1 (id int, a varchar(30) character set utf32);
|
||||
INSERT INTO t1 VALUES (1, _ucs2 0x01310069), (2, _ucs2 0x01310131);
|
||||
INSERT INTO t1 VALUES (3, _ucs2 0x00690069), (4, _ucs2 0x01300049);
|
||||
INSERT INTO t1 VALUES (5, _ucs2 0x01300130), (6, _ucs2 0x00490049);
|
||||
SELECT a, length(a) la, @l:=lower(a) l, length(@l) ll, @u:=upper(a) u, length(@u) lu
|
||||
FROM t1 ORDER BY id;
|
||||
ALTER TABLE t1 MODIFY a VARCHAR(30) character set utf32 collate utf32_turkish_ci;
|
||||
SELECT a, length(a) la, @l:=lower(a) l, length(@l) ll, @u:=upper(a) u, length(@u) lu
|
||||
FROM t1 ORDER BY id;
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# Bug #27079 Crash while grouping empty ucs2 strings
|
||||
#
|
||||
CREATE TABLE t1 (
|
||||
c1 text character set utf32 collate utf32_polish_ci NOT NULL
|
||||
) ENGINE=MyISAM;
|
||||
insert into t1 values (''),('a');
|
||||
SELECT COUNT(*), c1 FROM t1 GROUP BY c1;
|
||||
DROP TABLE IF EXISTS t1;
|
||||
|
||||
|
||||
#
|
||||
# Test basic regex functionality
|
||||
#
|
||||
set collation_connection=utf32_unicode_ci;
|
||||
--source include/ctype_regex.inc
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # End of 5.5 tests
|
||||
--echo #
|
@ -1440,6 +1440,17 @@ DROP TABLE t1;
|
||||
|
||||
|
||||
--echo Start of 5.4 tests
|
||||
|
||||
#
|
||||
# WL#1213: utf8mb3 is an alias for utf8
|
||||
#
|
||||
SET NAMES utf8mb3;
|
||||
SHOW VARIABLES LIKE 'character_set_results%';
|
||||
CREATE TABLE t1 (a CHAR CHARACTER SET utf8mb3 COLLATE utf8mb3_bin);
|
||||
SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
SELECT _utf8mb3'test';
|
||||
|
||||
#
|
||||
# Bug#26180: Can't add columns to tables created with utf8 text indexes
|
||||
#
|
||||
|
1671
mysql-test/t/ctype_utf8mb4.test
Normal file
1671
mysql-test/t/ctype_utf8mb4.test
Normal file
File diff suppressed because it is too large
Load Diff
@ -291,6 +291,21 @@ DELETE FROM t1 ORDER BY (f1(10)) LIMIT 1;
|
||||
DROP TABLE t1;
|
||||
DROP FUNCTION f1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Bug #49552 : sql_buffer_result cause crash + not found records
|
||||
--echo # in multitable delete/subquery
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1(a INT);
|
||||
INSERT INTO t1 VALUES (1),(2),(3);
|
||||
SET SESSION SQL_BUFFER_RESULT=1;
|
||||
DELETE t1 FROM (SELECT SUM(a) a FROM t1) x,t1;
|
||||
|
||||
SET SESSION SQL_BUFFER_RESULT=DEFAULT;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
||||
#
|
||||
@ -513,18 +528,4 @@ DELETE IGNORE FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Bug #49552 : sql_buffer_result cause crash + not found records
|
||||
--echo # in multitable delete/subquery
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1(a INT);
|
||||
INSERT INTO t1 VALUES (1),(2),(3);
|
||||
SET SESSION SQL_BUFFER_RESULT=1;
|
||||
DELETE t1 FROM (SELECT SUM(a) a FROM t1) x,t1;
|
||||
|
||||
SET SESSION SQL_BUFFER_RESULT=DEFAULT;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
@ -553,6 +553,27 @@ SELECT count(*) FROM t1 WHERE
|
||||
|
||||
DROP TABLE t1,t2,t3;
|
||||
|
||||
#
|
||||
# BUG#50351 - ft_min_word_len=2 Causes query to hang
|
||||
#
|
||||
CREATE TABLE t1 (a VARCHAR(4), FULLTEXT(a));
|
||||
INSERT INTO t1 VALUES
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),
|
||||
('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('cwrd'),('awrd'),('cwrd'),
|
||||
('awrd');
|
||||
SELECT COUNT(*) FROM t1 WHERE MATCH(a) AGAINST("+awrd bwrd* +cwrd*" IN BOOLEAN MODE);
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #49445: Assertion failed: 0, file .\item_row.cc, line 55 with
|
||||
|
@ -693,6 +693,21 @@ SELECT 1 FROM t1 WHERE t1.a NOT IN
|
||||
|
||||
DROP TABLE t1, t2;
|
||||
|
||||
#
|
||||
# Bug #49487: crash with explain extended and group_concat in a derived table
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (f1 INT);
|
||||
INSERT INTO t1 VALUES (),();
|
||||
|
||||
EXPLAIN EXTENDED SELECT 1 FROM
|
||||
(SELECT DISTINCT GROUP_CONCAT(td.f1) FROM t1,t1 AS td GROUP BY td.f1) AS d,t1;
|
||||
|
||||
SELECT 1 FROM
|
||||
(SELECT DISTINCT GROUP_CONCAT(td.f1) FROM t1,t1 AS td GROUP BY td.f1) AS d,t1;
|
||||
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
||||
#
|
||||
|
@ -442,7 +442,7 @@ where collation(t2.a) = _utf8'binary' order by t1.a,t2.a;
|
||||
select t1.*,t2.* from t1 left join t2 on (t1.b=t2.b)
|
||||
where charset(t2.a) = _utf8'binary' order by t1.a,t2.a;
|
||||
select t1.*,t2.* from t1 left join t2 on (t1.b=t2.b)
|
||||
where coercibility(t2.a) = 2 order by t1.a,t2.a;
|
||||
where coercibility(t2.a) = 5 order by t1.a,t2.a;
|
||||
DROP TABLE t1, t2;
|
||||
|
||||
#
|
||||
|
@ -1159,3 +1159,53 @@ SELECT COUNT(i) FROM t1 WHERE i > 1;
|
||||
DROP TABLE t1;
|
||||
SET @@sql_mode = @old_sql_mode;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #45640: optimizer bug produces wrong results
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 (a INT, b INT);
|
||||
INSERT INTO t1 VALUES (4, 40), (1, 10), (2, 20), (2, 20), (3, 30);
|
||||
|
||||
--echo # should return 4 ordered records:
|
||||
SELECT (SELECT t1.a) aa, COUNT(DISTINCT b) FROM t1 GROUP BY aa;
|
||||
|
||||
SELECT (SELECT (SELECT t1.a)) aa, COUNT(DISTINCT b) FROM t1 GROUP BY aa;
|
||||
|
||||
SELECT (SELECT t1.a) aa, COUNT(DISTINCT b) FROM t1 GROUP BY aa+0;
|
||||
|
||||
--echo # should return the same result in a reverse order:
|
||||
SELECT (SELECT t1.a) aa, COUNT(DISTINCT b) FROM t1 GROUP BY -aa;
|
||||
|
||||
--echo # execution plan should not use temporary table:
|
||||
EXPLAIN EXTENDED
|
||||
SELECT (SELECT t1.a) aa, COUNT(DISTINCT b) FROM t1 GROUP BY aa+0;
|
||||
|
||||
EXPLAIN EXTENDED
|
||||
SELECT (SELECT t1.a) aa, COUNT(DISTINCT b) FROM t1 GROUP BY -aa;
|
||||
|
||||
--echo # should return only one record
|
||||
SELECT (SELECT tt.a FROM t1 tt LIMIT 1) aa, COUNT(DISTINCT b) FROM t1
|
||||
GROUP BY aa;
|
||||
|
||||
CREATE TABLE t2 SELECT DISTINCT a FROM t1;
|
||||
|
||||
--echo # originally reported queries (1st two columns of next two query
|
||||
--echo # results should be same):
|
||||
|
||||
SELECT (SELECT t2.a FROM t2 WHERE t2.a = t1.a) aa, b, COUNT(DISTINCT b)
|
||||
FROM t1 GROUP BY aa, b;
|
||||
SELECT (SELECT t2.a FROM t2 WHERE t2.a = t1.a) aa, b, COUNT( b)
|
||||
FROM t1 GROUP BY aa, b;
|
||||
|
||||
--echo # ORDER BY for sure:
|
||||
|
||||
SELECT (SELECT t2.a FROM t2 WHERE t2.a = t1.a) aa, b, COUNT(DISTINCT b)
|
||||
FROM t1 GROUP BY aa, b ORDER BY -aa, -b;
|
||||
SELECT (SELECT t2.a FROM t2 WHERE t2.a = t1.a) aa, b, COUNT( b)
|
||||
FROM t1 GROUP BY aa, b ORDER BY -aa, -b;
|
||||
|
||||
DROP TABLE t1, t2;
|
||||
|
||||
--echo #
|
||||
|
||||
--echo # End of 5.1 tests
|
||||
|
@ -1044,6 +1044,16 @@ SELECT a, MAX(b) FROM t WHERE b GROUP BY a;
|
||||
|
||||
DROP TABLE t;
|
||||
|
||||
#
|
||||
# BUG#49902 - SELECT returns incorrect results
|
||||
#
|
||||
CREATE TABLE t1(a INT NOT NULL, b INT NOT NULL, KEY (b));
|
||||
INSERT INTO t1 VALUES(1,1),(2,1);
|
||||
ANALYZE TABLE t1;
|
||||
SELECT 1 AS c, b FROM t1 WHERE b IN (1,2) GROUP BY c, b;
|
||||
SELECT a FROM t1 WHERE b=1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
||||
|
||||
|
@ -442,4 +442,30 @@ INSERT INTO t1 VALUES (1, 1), (2,2), (3, NULL);
|
||||
SELECT b, COUNT(DISTINCT a) FROM t1 GROUP BY b HAVING b is NULL;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Bug#50995 Having clause on subquery result produces incorrect results.
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1
|
||||
(
|
||||
id1 INT,
|
||||
id2 INT NOT NULL,
|
||||
INDEX id1(id2)
|
||||
);
|
||||
|
||||
INSERT INTO t1 SET id1=1, id2=1;
|
||||
INSERT INTO t1 SET id1=2, id2=1;
|
||||
INSERT INTO t1 SET id1=3, id2=1;
|
||||
|
||||
SELECT t1.id1,
|
||||
(SELECT 0 FROM DUAL
|
||||
WHERE t1.id1=t1.id1) AS amount FROM t1
|
||||
WHERE t1.id2 = 1
|
||||
HAVING amount > 0
|
||||
ORDER BY t1.id1;
|
||||
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
@ -536,6 +536,28 @@ DROP PROCEDURE p1;
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1,t2;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # Bug #49324: more valgrind errors in test_if_skip_sort_order
|
||||
--echo #
|
||||
CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=innodb ;
|
||||
--echo #should not cause valgrind warnings
|
||||
SELECT 1 FROM t1 JOIN t1 a USING(a) GROUP BY t1.a,t1.a;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#50843: Filesort used instead of clustered index led to
|
||||
--echo # performance degradation.
|
||||
--echo #
|
||||
create table t1(f1 int not null primary key, f2 int) engine=innodb;
|
||||
create table t2(f1 int not null, key (f1)) engine=innodb;
|
||||
insert into t1 values (1,1),(2,2),(3,3);
|
||||
insert into t2 values (1),(2),(3);
|
||||
explain select t1.* from t1 left join t2 using(f1) group by t1.f1;
|
||||
drop table t1,t2;
|
||||
--echo #
|
||||
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
||||
|
||||
|
@ -804,3 +804,28 @@ DEALLOCATE PREPARE stmt;
|
||||
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1, t2;
|
||||
|
||||
#
|
||||
# Bug#45195 valgrind warnings about uninitialized values in store_record_in_cache()
|
||||
#
|
||||
CREATE TABLE t1(a CHAR(9),b INT,KEY(b),KEY(a)) ENGINE=MYISAM;
|
||||
CREATE TABLE t2(a CHAR(9),b INT,KEY(b),KEY(a)) ENGINE=MYISAM;
|
||||
INSERT INTO t1 VALUES ('1',null),(null,null);
|
||||
INSERT INTO t2 VALUES ('1',null),(null,null);
|
||||
CREATE TABLE mm1(a CHAR(9),b INT,KEY(b),KEY(a))
|
||||
ENGINE=MERGE UNION=(t1,t2);
|
||||
SELECT t1.a FROM mm1,t1;
|
||||
DROP TABLE t1, t2, mm1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #50335: Assertion `!(order->used & map)' in eq_ref_table
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 (a INT NOT NULL, b INT NOT NULL, PRIMARY KEY (a,b));
|
||||
INSERT INTO t1 VALUES (0,0), (1,1);
|
||||
|
||||
SELECT * FROM t1 STRAIGHT_JOIN t1 t2 ON t1.a=t2.a AND t1.a=t2.b ORDER BY t2.a, t1.a;
|
||||
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
@ -638,5 +638,17 @@ drop table t1, t2, t3;
|
||||
# Add further tests from here
|
||||
#
|
||||
|
||||
--echo #
|
||||
--echo # Bug#49534: multitable IGNORE update with sql_safe_updates error
|
||||
--echo # causes debug assertion
|
||||
--echo #
|
||||
CREATE TABLE t1( a INT, KEY( a ) );
|
||||
INSERT INTO t1 VALUES (1), (2), (3);
|
||||
SET SESSION sql_safe_updates = 1;
|
||||
--echo # Must not cause failed assertion
|
||||
--error ER_UPDATE_WITHOUT_KEY_IN_SAFE_MODE
|
||||
UPDATE IGNORE t1, t1 t1a SET t1.a = 1 WHERE t1a.a = 1;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo end of tests
|
||||
|
@ -1200,6 +1200,17 @@ CHECKSUM TABLE t1 EXTENDED;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # BUG#48438 - crash with error in unioned query against merge table and view...
|
||||
--echo #
|
||||
SET GLOBAL table_open_cache=3;
|
||||
CREATE TABLE t1(a INT);
|
||||
SELECT 1 FROM t1 AS a1, t1 AS a2, t1 AS a3, t1 AS a4 FOR UPDATE;
|
||||
SELECT TABLE_ROWS, DATA_LENGTH FROM INFORMATION_SCHEMA.TABLES
|
||||
WHERE TABLE_SCHEMA='test' AND TABLE_NAME='t1';
|
||||
DROP TABLE t1;
|
||||
SET GLOBAL table_open_cache=DEFAULT;
|
||||
|
||||
--echo End of 5.0 tests
|
||||
|
||||
|
||||
@ -1565,5 +1576,18 @@ SET myisam_sort_buffer_size=@@global.myisam_sort_buffer_size;
|
||||
CHECK TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # BUG#49628 - corrupt table after legal SQL, LONGTEXT column
|
||||
--echo #
|
||||
CREATE TABLE t1(a INT, b LONGTEXT, UNIQUE(a));
|
||||
REPLACE INTO t1 VALUES
|
||||
(1, REPEAT('a', 129015)),(1, NULL),
|
||||
(2, NULL),(3, NULL),(4, NULL),(5, NULL),(6, NULL),(7, NULL),
|
||||
(1, REPEAT('b', 129016)),(1, NULL),
|
||||
(1, REPEAT('c', 129015)),(1, REPEAT('d', 129015));
|
||||
CHECK TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
||||
|
6
mysql-test/t/no_binlog.test
Normal file
6
mysql-test/t/no_binlog.test
Normal file
@ -0,0 +1,6 @@
|
||||
-- source include/not_embedded.inc
|
||||
|
||||
# BUG#50780: 'show binary logs' debug assertion when binary logging is disabled
|
||||
|
||||
-- error ER_NO_BINARY_LOGGING
|
||||
SHOW BINARY LOGS;
|
89
mysql-test/t/partition_debug_sync.test
Normal file
89
mysql-test/t/partition_debug_sync.test
Normal file
@ -0,0 +1,89 @@
|
||||
#--disable_abort_on_error
|
||||
#
|
||||
# Test for the partition storage engine which require DEBUG_SYNC feature to
|
||||
# Created by Mattias Jonsson
|
||||
#
|
||||
--source include/have_partition.inc
|
||||
--source include/have_debug_sync.inc
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1, t2;
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
--enable_warnings
|
||||
|
||||
--echo #
|
||||
--echo # Bug#42438: Crash ha_partition::change_table_ptr
|
||||
--echo # Test when remove partitioning is done while drop table is waiting
|
||||
--echo # for the table.
|
||||
--echo # After MDL was introduced, there is no longer any race, so test is done
|
||||
--echo # by adding a small sleep to verify that the delete waits.
|
||||
connect(con1, localhost, root,,);
|
||||
--echo # Con 1
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
CREATE TABLE t1
|
||||
(a INTEGER,
|
||||
b INTEGER NOT NULL,
|
||||
KEY (b))
|
||||
ENGINE = MYISAM
|
||||
/*!50100 PARTITION BY RANGE (a)
|
||||
(PARTITION p0 VALUES LESS THAN (2),
|
||||
PARTITION p1 VALUES LESS THAN (20),
|
||||
PARTITION p2 VALUES LESS THAN (100),
|
||||
PARTITION p3 VALUES LESS THAN MAXVALUE ) */;
|
||||
SET SESSION debug= "+d,sleep_before_create_table_no_lock";
|
||||
SET DEBUG_SYNC= 'alter_table_before_create_table_no_lock SIGNAL removing_partitioning WAIT_FOR waiting_for_alter';
|
||||
SET DEBUG_SYNC= 'alter_table_before_main_binlog SIGNAL partitioning_removed';
|
||||
--send ALTER TABLE t1 REMOVE PARTITIONING
|
||||
connection default;
|
||||
--echo # Con default
|
||||
SET DEBUG_SYNC= 'now WAIT_FOR removing_partitioning';
|
||||
SET DEBUG_SYNC= 'mdl_acquire_lock_wait SIGNAL waiting_for_alter';
|
||||
SET DEBUG_SYNC= 'rm_table_part2_before_delete_table WAIT_FOR partitioning_removed';
|
||||
DROP TABLE IF EXISTS t1;
|
||||
--echo # Con 1
|
||||
connection con1;
|
||||
--reap
|
||||
SET SESSION debug= "-d,sleep_before_create_table_no_lock";
|
||||
connection default;
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
connection con1;
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
|
||||
--echo #
|
||||
--echo # Bug#42438: Crash ha_partition::change_table_ptr
|
||||
--echo # Test when remove partitioning is failing due to drop table is already
|
||||
--echo # in progress.
|
||||
--echo # After MDL was introduced, there is no longer any race, so test is done
|
||||
--echo # by adding a small sleep to verify that the alter waits.
|
||||
CREATE TABLE t2
|
||||
(a INTEGER,
|
||||
b INTEGER NOT NULL,
|
||||
KEY (b))
|
||||
ENGINE = MYISAM
|
||||
/*!50100 PARTITION BY RANGE (a)
|
||||
(PARTITION p0 VALUES LESS THAN (2),
|
||||
PARTITION p1 VALUES LESS THAN (20),
|
||||
PARTITION p2 VALUES LESS THAN (100),
|
||||
PARTITION p3 VALUES LESS THAN MAXVALUE ) */;
|
||||
SET DEBUG_SYNC= 'open_tables_acquire_upgradable_mdl SIGNAL removing_partitions WAIT_FOR waiting_for_alter';
|
||||
SET DEBUG_SYNC= 'alter_table_before_rename_result_table WAIT_FOR delete_done';
|
||||
--send ALTER TABLE t2 REMOVE PARTITIONING
|
||||
connection default;
|
||||
--echo # Con default
|
||||
SET SESSION debug= "+d,sleep_before_part2_delete_table";
|
||||
SET DEBUG_SYNC= 'now WAIT_FOR removing_partitions';
|
||||
SET DEBUG_SYNC= 'rm_table_part2_before_delete_table SIGNAL waiting_for_alter';
|
||||
SET DEBUG_SYNC= 'rm_table_part2_before_binlog SIGNAL delete_done';
|
||||
DROP TABLE IF EXISTS t2;
|
||||
SET SESSION debug= "-d,sleep_before_part2_delete_table";
|
||||
--echo # Con 1
|
||||
connection con1;
|
||||
--error ER_NO_SUCH_TABLE
|
||||
--reap
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
disconnect con1;
|
||||
connection default;
|
||||
--echo # Con default
|
||||
SET DEBUG_SYNC= 'RESET';
|
||||
|
||||
--echo End of 5.1 tests
|
@ -57,5 +57,48 @@ SELECT f2 ();
|
||||
|
||||
DROP SCHEMA testdb;
|
||||
|
||||
USE test;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#50423: Crash on second call of a procedure dropping a trigger
|
||||
--echo #
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
DROP TRIGGER IF EXISTS tr1;
|
||||
DROP PROCEDURE IF EXISTS p1;
|
||||
--enable_warnings
|
||||
|
||||
CREATE TABLE t1 (f1 INTEGER);
|
||||
CREATE TRIGGER tr1 BEFORE INSERT ON t1 FOR EACH ROW SET @aux = 1;
|
||||
CREATE PROCEDURE p1 () DROP TRIGGER tr1;
|
||||
|
||||
CALL p1 ();
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
CALL p1 ();
|
||||
|
||||
DROP TABLE t1;
|
||||
DROP PROCEDURE p1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#50423: Crash on second call of a procedure dropping a trigger
|
||||
--echo #
|
||||
|
||||
--disable_warnings
|
||||
DROP TABLE IF EXISTS t1;
|
||||
DROP TRIGGER IF EXISTS tr1;
|
||||
DROP PROCEDURE IF EXISTS p1;
|
||||
--enable_warnings
|
||||
|
||||
CREATE TABLE t1 (f1 INTEGER);
|
||||
CREATE TRIGGER tr1 BEFORE INSERT ON t1 FOR EACH ROW SET @aux = 1;
|
||||
CREATE PROCEDURE p1 () DROP TRIGGER tr1;
|
||||
|
||||
CALL p1 ();
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
CALL p1 ();
|
||||
|
||||
DROP TABLE t1;
|
||||
DROP PROCEDURE p1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
@ -413,6 +413,43 @@ let $wait_condition=
|
||||
--source include/wait_condition.inc
|
||||
DROP PROCEDURE p;
|
||||
|
||||
#
|
||||
# Bug#47736 killing a select from a view when the view is processing a function, asserts
|
||||
#
|
||||
CREATE TABLE t1(a int);
|
||||
INSERT INTO t1 VALUES (1);
|
||||
CREATE FUNCTION f1 (inp TEXT) RETURNS INT NO SQL RETURN sleep(60);
|
||||
CREATE VIEW v1 AS SELECT f1('a') FROM t1;
|
||||
|
||||
--connect (con1, localhost, root,,)
|
||||
--let $ID_1= `SELECT connection_id()`
|
||||
--send SELECT * FROM v1;
|
||||
|
||||
--connect (con2, localhost, root,,)
|
||||
--let $ID_2= `SELECT connection_id()`
|
||||
--send SELECT * FROM v1
|
||||
|
||||
--connection default
|
||||
--disable_query_log
|
||||
--eval KILL QUERY $ID_2
|
||||
--eval KILL QUERY $ID_1
|
||||
--enable_query_log
|
||||
|
||||
--connection con1
|
||||
--error ER_QUERY_INTERRUPTED
|
||||
--reap
|
||||
--connection con2
|
||||
--error ER_QUERY_INTERRUPTED
|
||||
--reap
|
||||
|
||||
--connection default
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1;
|
||||
DROP FUNCTION f1;
|
||||
--disconnect con1
|
||||
--disconnect con2
|
||||
|
||||
|
||||
--echo # ------------------------------------------------------------------
|
||||
--echo # -- End of 5.1 tests
|
||||
--echo # ------------------------------------------------------------------
|
||||
|
@ -3820,4 +3820,21 @@ SELECT 1 FROM t1 WHERE a <> SOME
|
||||
);
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #45989 take 2 : memory leak after explain encounters an
|
||||
--echo # error in the query
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1(a LONGTEXT);
|
||||
INSERT INTO t1 VALUES (repeat('a',@@global.max_allowed_packet));
|
||||
INSERT INTO t1 VALUES (repeat('b',@@global.max_allowed_packet));
|
||||
|
||||
--error ER_BAD_FIELD_ERROR
|
||||
EXPLAIN EXTENDED SELECT DISTINCT 1 FROM t1,
|
||||
(SELECT DISTINCTROW a AS away FROM t1 GROUP BY a WITH ROLLUP) AS d1
|
||||
WHERE t1.a = d1.a;
|
||||
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo End of 5.1 tests.
|
||||
|
@ -425,4 +425,17 @@ select hex(a) from t1;
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#50591 bit(31) causes Duplicate entry '1-NULL' for key 'group_key'
|
||||
--echo #
|
||||
CREATE TABLE t1(a INT, b BIT(7) NOT NULL);
|
||||
INSERT INTO t1 VALUES (NULL, 0),(NULL, 0);
|
||||
SELECT SUM(a) FROM t1 GROUP BY b, a;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1(a INT, b BIT(7) NOT NULL, c BIT(8) NOT NULL);
|
||||
INSERT INTO t1 VALUES (NULL, 0, 0),(NULL, 0, 0);
|
||||
SELECT SUM(a) FROM t1 GROUP BY c, b, a;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
@ -3906,6 +3906,52 @@ ALTER TABLE v1;
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#48449: hang on show create view after upgrading when
|
||||
--echo # view contains function of view
|
||||
--echo #
|
||||
|
||||
--disable_warnings
|
||||
DROP VIEW IF EXISTS v1,v2;
|
||||
DROP TABLE IF EXISTS t1,t2;
|
||||
DROP FUNCTION IF EXISTS f1;
|
||||
--enable_warnings
|
||||
|
||||
CREATE TABLE t1 (a INT);
|
||||
CREATE TABLE t2 (a INT);
|
||||
|
||||
delimiter //;
|
||||
CREATE FUNCTION f1() RETURNS INT
|
||||
BEGIN
|
||||
SELECT a FROM v2 INTO @a;
|
||||
RETURN @a;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
--echo # Trigger pre-locking when opening v2.
|
||||
CREATE VIEW v1 AS SELECT f1() FROM t1;
|
||||
|
||||
let $MYSQLD_DATADIR= `SELECT @@datadir`;
|
||||
copy_file std_data/bug48449.frm $MYSQLD_DATADIR/test/v2.frm;
|
||||
|
||||
SHOW CREATE VIEW v1;
|
||||
|
||||
DROP VIEW v1,v2;
|
||||
DROP TABLE t1,t2;
|
||||
DROP FUNCTION f1;
|
||||
|
||||
|
||||
#
|
||||
# Bug#48294 assertion when creating a view based on some row() construct in select query
|
||||
#
|
||||
CREATE TABLE t1(f1 INT);
|
||||
INSERT INTO t1 VALUES ();
|
||||
|
||||
CREATE VIEW v1 AS SELECT 1 FROM t1 WHERE
|
||||
ROW(1,1) >= ROW(1, (SELECT 1 FROM t1 WHERE f1 >= ANY ( SELECT '1' )));
|
||||
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo # -----------------------------------------------------------------
|
||||
--echo # -- End of 5.1 tests.
|
||||
|
@ -1532,3 +1532,17 @@ SELECT a FROM v2;
|
||||
--disconnect mysqluser1
|
||||
DROP USER mysqluser1;
|
||||
DROP DATABASE mysqltest1;
|
||||
USE test;
|
||||
|
||||
--echo #
|
||||
--echo # Bug#47734: Assertion failed: ! is_set() when locking a view with non-existing definer
|
||||
--echo #
|
||||
|
||||
--disable_warnings
|
||||
DROP VIEW IF EXISTS v1;
|
||||
--enable_warnings
|
||||
|
||||
CREATE DEFINER=`unknown`@`unknown` SQL SECURITY DEFINER VIEW v1 AS SELECT 1;
|
||||
--error ER_NO_SUCH_USER
|
||||
LOCK TABLES v1 READ;
|
||||
DROP VIEW v1;
|
||||
|
Reference in New Issue
Block a user