# # Test of SET with space # --disable_warnings drop table if exists t1; --enable_warnings create table t1 (a set (' ','a','b') not null); show create table t1; drop table t1; create table t1 (a set (' ','a','b ') not null default 'b '); show create table t1; drop table t1; CREATE TABLE t1 ( user varchar(64) NOT NULL default '', path varchar(255) NOT NULL default '', privilege set('select','RESERVED30','RESERVED29','RESERVED28','RESERVED27','RESERVED26', 'RESERVED25','RESERVED24','data.delete','RESERVED22','RESERVED21', 'RESERVED20','data.insert.none','data.insert.approve', 'data.insert.delete','data.insert.move','data.insert.propose', 'data.insert.reject','RESERVED13','RESERVED12','RESERVED11','RESERVED10', 'RESERVED09','data.update','RESERVED07','RESERVED06','RESERVED05', 'RESERVED04','metadata.delete','metadata.put','RESERVED01','RESERVED00') NOT NULL default '', KEY user (user) ) ENGINE=MyISAM CHARSET=utf8; DROP TABLE t1; # # Check that SET is case sensitive with a binary collation # set names latin1; create table t1 (s set ('a','A') character set latin1 collate latin1_bin); show create table t1; insert into t1 values ('a'),('a,A'),('A,a'),('A'); select s from t1 order by s; select s from t1 order by concat(s); drop table t1; # # Check that SET honors a more complex collation correctly # CREATE TABLE t1 (c set('ae','oe','ue','ss') collate latin1_german2_ci); INSERT INTO t1 VALUES ('�'),('�'),('�'),('�'); INSERT INTO t1 VALUES ('ae'),('oe'),('ue'),('ss'); INSERT INTO t1 VALUES ('�,�,�,�'); INSERT INTO t1 VALUES ('ae,oe,ue,ss'); SELECT c FROM t1 ORDER BY c; SELECT c FROM t1 ORDER BY concat(c); DROP TABLE t1; # End of 4.1 tests # # Bug#27069 set with identical elements are created # --error 1097 create table t1(f1 set('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17', '18','19','20','21','22','23','24','25','26','27','28','29','30','31','32','33', '34','35','36','37','38','39','40','41','42','43','44','45','46','47','48','49', '50','51','52','53','54','55','56','57','58','59','60','61','62','63','64','128')); create table t1(f1 set('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17', '18','19','20','21','22','23','24','25','26','27','28','29','30','31','32','33', '34','35','36','37','38','39','40','41','42','43','44','45','46','47','48','49', '50','51','52','53','54','55','56','57','58','59','60','61','62','63','64','1')); show create table t1; drop table t1; # # Bug#15409: Columns with SET datatype with 64-element sets # may not be updated with integers # let $i=64; let $s='$i'; dec $i; while ($i) { let $s='$i',$s; dec $i; } --eval CREATE TABLE t1(c set($s)) INSERT INTO t1 VALUES(7); INSERT INTO t1 VALUES(9223372036854775808); SELECT * FROM t1; DROP TABLE t1; # # Bug #38701: Crash in String::append when inserting duplicate empty strings # an uft8 SET col # CREATE TABLE t1 ( set_unique_utf8 set ('a','b','c','d','e','f','g','h','i','j','k','l', 'm','n','o','p','q','r','s','t','u','v','w','x', 'y','z') CHARACTER SET utf8, unique (set_unique_utf8) ); INSERT INTO t1 ( set_unique_utf8 ) VALUES ( '' ); --error ER_DUP_ENTRY INSERT INTO t1 ( set_unique_utf8 ) VALUES ( '' ); DROP TABLE t1; --echo End of 5.0 tests