下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

mysql数据库如何进行字符串转义?

作者:课课家教育     来源: http://www.kokojia.com点击数:3274发布时间: 2016-03-23 08:00:27

标签: mysql转义数据库mysql转义字符序列

  在利用MySQL进行转义之前,我们需要对mysql转义字符进行一定的了解,才能很好的进行mysql的转义工作。

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

mysql数据库如何进行字符串转义?数据库_mysql转义字符序列_课课家

  这些序列对大小写敏感。例如,‘\\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';

  +------------------------+

  |diSAPpearingbackslash|

  +------------------------+

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

  

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

  ·用转义特殊字符的函数处理字符串。例如,在C程序中,可以使用mysql_real_escape_string()CAPI函数来转义字符。参见25.2.3.52节,“mysql_real_escape_string()”。PerlDBI接口提供一个quote方法来将特殊字符转换为正确的转义序列。参见25.4节,“MySQLPerlAPI”。

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

赞(0)
踩(1)
分享到:
华为认证网络工程师 HCIE直播课视频教程