2003-05-23 10:55:49 +05:00
|
|
|
select database();
|
|
|
|
database()
|
|
|
|
test
|
|
|
|
select charset(database());
|
|
|
|
charset(database())
|
|
|
|
utf8
|
|
|
|
select database() = "test";
|
|
|
|
database() = "test"
|
|
|
|
1
|
|
|
|
select database() = _utf8"test";
|
|
|
|
database() = _utf8"test"
|
|
|
|
1
|
|
|
|
select database() = _latin1"test";
|
|
|
|
database() = _latin1"test"
|
|
|
|
1
|
|
|
|
select user() like "%@%";
|
|
|
|
user() like "%@%"
|
|
|
|
1
|
|
|
|
select user() like _utf8"%@%";
|
|
|
|
user() like _utf8"%@%"
|
|
|
|
1
|
|
|
|
select user() like _latin1"%@%";
|
|
|
|
user() like _latin1"%@%"
|
|
|
|
1
|
|
|
|
select charset(user());
|
|
|
|
charset(user())
|
|
|
|
utf8
|
|
|
|
select version()>="3.23.29";
|
|
|
|
version()>="3.23.29"
|
|
|
|
1
|
2003-03-19 19:13:28 +04:00
|
|
|
select version()>=_utf8"3.23.29";
|
|
|
|
version()>=_utf8"3.23.29"
|
2000-12-28 03:56:38 +02:00
|
|
|
1
|
2003-05-23 10:55:49 +05:00
|
|
|
select version()>=_latin1"3.23.29";
|
|
|
|
version()>=_latin1"3.23.29"
|
|
|
|
1
|
|
|
|
select charset(version());
|
|
|
|
charset(version())
|
|
|
|
utf8
|
2003-10-30 12:57:26 +02:00
|
|
|
explain extended select database(), user();
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
|
|
|
Warnings:
|
2006-06-27 21:28:32 +04:00
|
|
|
Note 1003 select database() AS `database()`,user() AS `user()`
|
2003-06-04 18:28:51 +03:00
|
|
|
create table t1 (version char(40)) select database(), user(), version() as 'version';
|
2003-05-23 10:55:49 +05:00
|
|
|
show create table t1;
|
|
|
|
Table Create Table
|
|
|
|
t1 CREATE TABLE `t1` (
|
2004-12-07 15:47:00 +02:00
|
|
|
`database()` varchar(34) character set utf8 default NULL,
|
|
|
|
`user()` varchar(77) character set utf8 NOT NULL default '',
|
2003-08-11 18:18:34 +05:00
|
|
|
`version` char(40) default NULL
|
2003-12-10 04:31:42 +00:00
|
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
2003-05-23 10:55:49 +05:00
|
|
|
drop table t1;
|
2004-02-11 16:53:39 +04:00
|
|
|
select charset(charset(_utf8'a')), charset(collation(_utf8'a'));
|
|
|
|
charset(charset(_utf8'a')) charset(collation(_utf8'a'))
|
|
|
|
utf8 utf8
|
|
|
|
select collation(charset(_utf8'a')), collation(collation(_utf8'a'));
|
|
|
|
collation(charset(_utf8'a')) collation(collation(_utf8'a'))
|
|
|
|
utf8_general_ci utf8_general_ci
|
|
|
|
create table t1 select charset(_utf8'a'), collation(_utf8'a');
|
|
|
|
show create table t1;
|
|
|
|
Table Create Table
|
|
|
|
t1 CREATE TABLE `t1` (
|
2004-12-07 15:47:00 +02:00
|
|
|
`charset(_utf8'a')` varchar(64) character set utf8 NOT NULL default '',
|
|
|
|
`collation(_utf8'a')` varchar(64) character set utf8 NOT NULL default ''
|
2004-02-11 16:53:39 +04:00
|
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
|
|
drop table t1;
|
2002-11-21 02:07:14 +02:00
|
|
|
select TRUE,FALSE,NULL;
|
|
|
|
TRUE FALSE NULL
|
|
|
|
1 0 NULL
|
2005-08-08 19:09:54 +05:00
|
|
|
create table t1 (c1 char(5)) character set=latin1;
|
|
|
|
insert into t1 values('row 1');
|
|
|
|
insert into t1 values('row 2');
|
|
|
|
insert into t1 values('row 3');
|
|
|
|
select concat(user(), '--', c1) from t1;
|
|
|
|
concat(user(), '--', c1)
|
|
|
|
root@localhost--row 1
|
|
|
|
root@localhost--row 2
|
|
|
|
root@localhost--row 3
|
|
|
|
select concat(database(), '--', c1) from t1;
|
|
|
|
concat(database(), '--', c1)
|
|
|
|
test--row 1
|
|
|
|
test--row 2
|
|
|
|
test--row 3
|
|
|
|
drop table t1;
|
type_blob.result, func_system.result, func_str.result, ctype_collate.result:
fixing test results accordingly.
func_system.test:
New test that illegal mix of collations does not happen anymore.
item_strfunc.h:
safe_charset_converter() was added for system constants.
item_strfunc.cc:
safe_charset_converter() was added for system constants.
item_func.cc, item.h, item.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
item_create.cc:
Version is a system constant too.
sql/item.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item.h:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item_create.cc:
Version is a system constant too.
sql/item_func.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item_strfunc.cc:
safe_charset_converter() was added for system constants.
sql/item_strfunc.h:
safe_charset_converter() was added for system constants.
mysql-test/t/func_system.test:
New test that illegal mix of collations does not happen anymore.
mysql-test/r/ctype_collate.result:
fixing test results accordingly.
mysql-test/r/func_str.result:
fixing test results accordingly.
mysql-test/r/func_system.result:
fixing test results accordingly.
mysql-test/r/type_blob.result:
fixing test results accordingly.
2005-03-04 14:20:49 +04:00
|
|
|
create table t1 (a char(10)) character set latin1;
|
|
|
|
select * from t1 where a=version();
|
|
|
|
a
|
|
|
|
select * from t1 where a=database();
|
|
|
|
a
|
|
|
|
select * from t1 where a=user();
|
|
|
|
a
|
2005-03-28 12:24:12 +05:00
|
|
|
insert into t1 values ('a');
|
|
|
|
select left(concat(a,version()),1) from t1;
|
|
|
|
left(concat(a,version()),1)
|
|
|
|
a
|
type_blob.result, func_system.result, func_str.result, ctype_collate.result:
fixing test results accordingly.
func_system.test:
New test that illegal mix of collations does not happen anymore.
item_strfunc.h:
safe_charset_converter() was added for system constants.
item_strfunc.cc:
safe_charset_converter() was added for system constants.
item_func.cc, item.h, item.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
item_create.cc:
Version is a system constant too.
sql/item.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item.h:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item_create.cc:
Version is a system constant too.
sql/item_func.cc:
Bug#8291: Illegal collation mix with USER() function.
After discussion with PeterG and Serge, a new coercibility
level for "system constants" was introduced, between
COERRIBLE and IMPLICIT. Thus:
SELECT col1 = USER() FROM t1; - is done according to col1 collation.
SELECT 'string' = USER(); - is done according to USER() collation.
At the same time, "nagg" and "strong" members were removed as unused.
sql/item_strfunc.cc:
safe_charset_converter() was added for system constants.
sql/item_strfunc.h:
safe_charset_converter() was added for system constants.
mysql-test/t/func_system.test:
New test that illegal mix of collations does not happen anymore.
mysql-test/r/ctype_collate.result:
fixing test results accordingly.
mysql-test/r/func_str.result:
fixing test results accordingly.
mysql-test/r/func_system.result:
fixing test results accordingly.
mysql-test/r/type_blob.result:
fixing test results accordingly.
2005-03-04 14:20:49 +04:00
|
|
|
drop table t1;
|