mysql转义字符
2016-02-24 11:46
543 查看
在字符串中,某些序列具有特殊含义。这些序列均用反斜线(‘\’)开始,即所谓的转义字符。MySQL识别下面的转义序列:
\0 | ASCII0(NUL)字符。 |
\' | 单引号(‘'’)。 |
\" | 双引号(‘"’)。 |
\b | 退格符。 |
\n | 换行符。 |
\r | 回车符。 |
\t | tab字符。 |
\Z | ASCII26(控制(Ctrl)-Z)。该字符可以编码为‘\Z’,以允许你解决在Windows中ASCII26代表文件结尾这一问题。(如果你试图使用mysql db_name<file_name,ASCII26会带来问题)。 |
\\ | 反斜线(‘\’)字符。 |
\% | ‘%’字符。参见表后面的注解。 |
\_ | ‘_’字符。参见表后面的注解。 |
‘\%’和‘\_’序列用于搜索可能会解释为通配符的模式匹配环境中的‘%’和‘_’文字实例。参见
在其它转义序列中,反斜线被忽略。也就是说,转义字符解释为仿佛没有转义。
有几种方式可以在字符串中包括引号:
·在字符串内用‘'’引用的‘'’可以写成‘''’。
·在字符串内用‘"’引用的‘"’可以写成‘""’。
·可以在引号前加转义字符(‘\’)。
·在字符串内用‘"’引用的‘'’不需要特殊处理,不需要用双字符或转义。同样,在字符串内用‘'’引用的‘"’也不需要特殊处理。
下面的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';
+------------------------+
|disappearingbackslash|
+------------------------+
如果你想要在字符串列内插入二进制数据(例如BLOB),必须通过转义序列表示下面的字符:
NUL | NUL字节(ASCII0)。用‘\0’表示该字符(反斜线后面跟一个ASCII‘0’字符)。 |
\ | 反斜线(ASCII92)。用‘\\’表示该字符。 |
' | 单引号(ASCII39)。用‘\'’表示该字符。 |
" | 双引号(ASCII34)。用‘\"’表示该字符。 |
·用转义特殊字符的函数处理字符串。例如,在C程序中,可以使用mysql_real_escape_string()CAPI函数来转义字符。参见
DBI接口提供一个quote方法来将特殊字符转换为正确的转义序列。参见
·显式转义特殊字符,许多MySQLAPI提供了占位符功能,允许你在查询字符串中插入特殊标记,然后当你发出查询时将数据值同它们绑定起来。在这种情况下,API关注转义值中的特殊字符。
好文要
相关文章推荐
- mysql存储过程语法大全
- 在sqlserver下增加MYSQL的链接服务…
- Mysql中文乱码解决方案(转)
- Mysql字段添加和修改
- mysql5.6新特性总结
- MySQL数据库事务隔离级别(Transaction Isolation Level)(顶)
- MySQL zabbix 流量统计分析脚本(内部业务需求)
- 如何修改mysql 并发数
- mySql ERROR 1046(3D000): No Datab
- MySQL 清除表空间碎片
- MySQL大量数据插入各种方法性能分析与比较
- mysqldump导入导出数据库基本方法
- Mysql 导入数据库方法 及失败解决
- MySQL新建用户,授权,删除用户,修改密码
- mysql数据库目录存放位置更改
- Mysql授权远程访问
- MySQL命令行合集
- mysql: command not found
- Mysql分表和分区的区别
- Wamp配置mysql编码