ASCII 0(NUL)字符。\'单引号(‘'’)。\"双引号(‘&qu"og:type" content="webpage">ASCII 0(NUL)字符。\'单引号(‘'’)。\"双引号(‘&qu" /> ASCII 0(NUL)字符。\'单引号(‘'’)。\"双引号(‘&qu"> mysql 5.7 不知道是否有转义字符_IT百科_内存溢出

阅读 13

mysql 5.7 不知道是否有转义字符,第1张

MySql字符转义

字符串

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

\0

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’。

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

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

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

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

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

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

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

下面的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函数来转义字符。参见25.2.3.52节,“mysql_real_escape_string()”。Perl DBI接口提供一个quote方法来将特殊字符转换为正确的转义序列。参见25.4节,“MySQL Perl API”。

· 显式转义特殊字符,许多MySQL API提供了占位符功能,允许你在查询字符串中插入特殊标记,然后当你发出查询时将数据值同它们绑定起来。在这种情况下,API关注转义值中的特殊字符。
转义字符的意思(十进制)\贝尔(BEL)007 \ b退格(BS)008 \ f换页(FF)012 \ n换行(LF)010 \ r回车符的ASCII码值(CR)013 \ t水平标签(HT)009 \ v垂直制表(VT)011 \\反斜杠092 \?问号字符063 \'单引号字符039 \“双引号字符034 \ 0空字符(NULL)000 \ DDD任意字符三位八进制\ XHH任何两个十六进制字符

欢迎分享,转载请注明来源:

内存溢出

原文地址:

http://outofmemory.cn/bake/11497958.html
斜线
(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
血型遗传表 血型遗传表 一级用户组
易控怎么使用方法?
上一篇
2023-05-16
angularjs的ng-repeat循环列表中序号怎么写
2023-05-16

发表评论
请登录后评论... 登录
提交

    评论列表(0条)
保存
{label} {label}