MySQL中字符串知识学习--MySql语法

2021-07-30 16:33:02 浏览数 (1)

本文学习的是Mysql字条串相关知识,字符串指用单引号(‘'’)或双引号(‘"’)引起来的字符序列。例如:

代码语言:javascript复制
'a string'
代码语言:javascript复制
"another string"

如果SQL服务器模式启用了NSI_QUOTES,可以只用单引号引用字符串。用双引号引用的字符串被解释为一个识别符。

字符串可以有一个可选字符集引介词和COLLATE子句:

代码语言:javascript复制
[_charset_name]'string' [COLLATE collation_name]

例如:

代码语言:javascript复制
SELECT _latin1'string';
代码语言:javascript复制
SELECT _latin1'string' COLLATE latin1_danish_ci;

关于这些字符串语法形式的详细信息,

在字符串中,某些序列具有特殊含义。这些序列均用反斜线(‘’)开始,即所谓的转义字符。MySQL识别下面的转义序列:

ASCII 0(NUL)字符。

'

单引号(‘'’)。

"

双引号(‘"’)。

b

退格符。

n

换行符。

r

回车符。

t

tab字符。

Z

ASCII 26(控制(Ctrl)-Z)。该字符可以编码为‘Z’,以允许你解决在Windows中ASCII 26代表文件结尾这一问题。(如果你试图使用mysql db_name < file_name,ASCII 26会带来问题)。

\

反斜线(‘’)字符。

%

‘%’字符。参见表后面的注解。

_

‘_’字符。参见表后面的注解。

这些序列对大小写敏感。例如,‘b’解释为退格,但‘B’解释为‘B’。

‘%’和‘_’序列用于搜索可能会解释为通配符的模式匹配环境中的‘%’和‘_’文字实例。请注意如果你在其它环境中使用‘%’或‘_’,它们返回字符串‘%’和‘_’,而不是‘%’和‘_’。

在其它转义序列中,反斜线被忽略。也就是说,转义字符解释为仿佛没有转义。

有几种方式可以在字符串中包括引号:

· 在字符串内用‘'’引用的‘'’可以写成‘''’。

· 在字符串内用‘"’引用的‘"’可以写成‘""’。

· 可以在引号前加转义字符(‘’)。

· 在字符串内用‘"’引用的‘'’不需要特殊处理,不需要用双字符或转义。同样,在字符串内用‘'’引用的‘"’也不需要特殊处理。

下面的SELECT语句显示了引用和转义如何工作:

代码语言:javascript复制
mysql> SELECT 'hello', '"hello"', '""hello""', 'hel''lo', ''hello';
 ------- --------- ----------- -------- -------- 
| hello | "hello" | ""hello"" | hel'lo | 'hello |
 ------- --------- ----------- -------- -------- 

mysql> SELECT "hello", "'hello'", "''hello''", "hel""lo", ""hello";
 ------- --------- ----------- -------- -------- 
| hello | 'hello' | ''hello'' | hel"lo | "hello |
 ------- --------- ----------- -------- -------- 

mysql> SELECT 'ThisnIsnFournLines';
 -------------------- 
| This
Is
Four
Lines |
 -------------------- 

mysql> SELECT 'disappearing backslash';
 ------------------------ 
| disappearing backslash |
 ------------------------ 

如果你想要在字符串列内插入二进制数据(例如BLOB),必须通过转义序列表示下面的字符:

NUL

NUL字节(ASCII 0)。用‘’表示该字符(反斜线后面跟一个ASCII‘0’字符)。

反斜线(ASCII 92)。用‘\’表示该字符。

'

单引号(ASCII 39)。用‘'’表示该字符。

"

双引号(ASCII 34)。用‘"’表示该字符。

当编写应用程序时,在包含这些特殊字符的字符串用于发送到MySQL服务器的SQL语句中的数据值之前,必须对它们正确进行转义。可以用两种方法来完成:

· 用转义特殊字符的函数处理字符串。例如,在C程序中,可以使用mysql_real_escape_string() C API函数来转义字符。

· 显式转义特殊字符,许多MySQL API提供了占位符功能,允许你在查询字符串中插入特殊标记,然后当你发出查询时将数据值同它们绑定起来。在这种情况下,API关注转义值中的特殊字符。

0 人点赞