MySql字符转义
在字符串中,某些序列具有特殊含义。这些序列均⽤反斜线(‘\’)开始,即所谓的转义字符。MySQL识别下⾯的转义序列:
\0ASCII 0(NUL)字符。
\'单引号(‘'’)。
\"双引号(‘"’)。
\b退格符。
mysql 字符串转数组\n换⾏符。
\r回车符。
\t tab字符。
\Z ASCII 26(控制(Ctrl)-Z)。该字符可以编码为‘\Z’,以允许你解决在Windows中ASCII 26代表⽂件结尾这⼀问题。(如果你试图使⽤mysql db_name < file_name,ASCII 26会带来问题)。
\\反斜线(‘\’)字符。
\%‘%’字符。参见表后⾯的注解。
\_‘_’字符。参见表后⾯的注解。
这些序列对⼤⼩写敏感。例如,‘\b’解释为退格,但‘\B’解释为‘B’。
‘\%’和‘\_’序列⽤于搜索可能会解释为通配符的模式匹配环境中的‘%’和‘_’⽂字实例。参见。请注意如果你在其它环境中使⽤‘\%’或‘\_’,它们返回字符串‘\%’和‘\_’,⽽不是‘%’和‘_’。
在其它转义序列中,反斜线被忽略。也就是说,转义字符解释为仿佛没有转义。
有⼏种⽅式可以在字符串中包括引号:
· 在字符串内⽤‘'’引⽤的‘'’可以写成‘''’。
· 在字符串内⽤‘"’引⽤的‘"’可以写成‘""’。
· 可以在引号前加转义字符(‘\’)。
·
在字符串内⽤‘"’引⽤的‘'’不需要特殊处理,不需要⽤双字符或转义。同样,在字符串内⽤‘'’引⽤的‘"’也不需要特殊处理。
下⾯的SELECT语句显⽰了引⽤和转义如何⼯作:
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 'This\nIs\nFour\nLines';
+--------------------+
| This
Is
Four
Lines |
+--------------------+
mysql> SELECT 'disappearing\ backslash';
+------------------------+
| disappearing backslash |
+------------------------+
如果你想要在字符串列内插⼊⼆进制数据(例如BLOB),必须通过转义序列表⽰下⾯的字符:
NUL NUL字节(ASCII 0)。⽤‘\0’表⽰该字符(反斜线后⾯跟⼀个ASCII‘0’字符)。
\反斜线(ASCII 92)。⽤‘\\’表⽰该字符。
'单引号(ASCII 39)。⽤‘\'’表⽰该字符。
"双引号(ASCII 34)。⽤‘\"’表⽰该字符。
当编写应⽤程序时,在包含这些特殊字符的字符串⽤于发送到MySQL服务器的SQL语句中的数据值之前,必须对它们正确进⾏转义。可以⽤两种⽅法来完成:
· ⽤转义特殊字符的函数处理字符串。例如,在C程序中,可以使⽤mysql_real_escape_string() C API函数来转义字符。参见。Perl DBI接⼝提供⼀个quote⽅法来将特殊字符转换为正确的转义序列。参见。
· 显式转义特殊字符,许多MySQL API提供了占位符功能,允许你在查询字符串中插⼊特殊标记,然后当你发出查询时将数据值同它们绑定起来。在这种情况下,API关注转义值中的特殊字符。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论