Character Set Introducers
A character string literal, hexadecimal literal, or bit-value literal may have an optional character set introducer and COLLATE
clause, to designate it as a string that uses a particular character set and collation:
[_charset_name] literal [COLLATE collation_name]
The _
expression is formally called an introducer. It tells the parser, “the string that follows uses character set charset_name
charset_name
.” An introducer does not change the string to the introducer character set like CONVERT()
would do. It does not change the string value, although padding may occur. The introducer is just a signal.
For character string literals, space between the introducer and the string is permitted but optional.
For character set literals, an introducer indicates the character set for the following string, but does not change how the parser performs escape processing within the string. Escapes are always interpreted by the parser according to the character set given by character_set_connection
. For additional discussion and examples, see Section 10.3.6, “Character String Literal Character Set and Collation”.
Examples:
SELECT 'abc';
SELECT _latin1'abc';
SELECT _binary'abc';
SELECT _utf8'abc' COLLATE utf8_danish_ci;
SELECT _latin1 X'4D7953514C';
SELECT _utf8 0x4D7953514C COLLATE utf8_danish_ci;
SELECT _latin1 b'1000001';
SELECT _utf8 0b1000001 COLLATE utf8_danish_ci;
Character set introducers and the COLLATE
clause are implemented according to standard SQL specifications.
- 点赞
- 收藏
- 关注作者
评论(0)