您的位置:网站主页> Mysql教程> MYSQL数据库 > mysql字符串讲解

mysql字符串讲解

时间:2018-06-04 18:37:01   编辑:一切随缘   文章来源:php教程网 已阅读:288 次

编程入门教程[www.ask186.com]网站介绍 

    编程入门教程主要涉及WEB开发领域,主要为广大WEB开发人员提供最新的WEB开发资讯信息,包含php教程mysql教程php面试题在线调色板php学习以及常用( Amazon ApiGoogle Api)等API、爱问资源共享HTML转JS不显示xml...[详细]
广告投放: 编程入门教程:www.ask186.com 电话:15818865556

        mysql字符串讲解

        字符串指用单引号(‘'’)或双引号(‘"’)引起来的字符序列。例如:

        'a string'
        "another string"

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

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

        [_charset_name]'string' [COLLATE collation_name]
        例如:

        SELECT _latin1'string';
        SELECT _latin1'string' COLLATE latin1_danish_ci;

        在字符串中,某些序列具有特殊含义。这些序列均用反斜线(‘\’)开始,即所谓的转义字符。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’。

        ‘\%’和‘\_’序列用于搜索可能会解释为通配符的模式匹配环境中的‘%’和‘_’文字实例。

        请注意如果你在其它环境中使用‘\%’或‘\_’,它们返回字符串‘\%’和‘\_’,而不是‘%’和‘_’。

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

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

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

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

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

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

        下面的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关注转义值中的特殊字符。

 

  • 上一篇:
  • 下一篇:

本文地址:http://www.ask186.com/content/article/mysql/database/31992.html(转载请保留)

相关关键词搜索:mysql,符串讲

发表评论
      
* 以上用户言论只代表其个人观点,不代表www.ask186.com网站的观点或立场
推荐文档更多
编程入门教程 | PHP教程 | Mysql教程 | Apache教程 | 最新文章 | PHP面试题| 网站地图 | Google地图 | Baidu地图 | 在线WEB论坛| 中纪委反腐最新消息

WEB技术QQ交流群:151963186 站长Q号:547214413
版权所有者:编程入门教程 地址:云南省文山州砚山县盘龙乡 滇ICP备12002707号-1
特别声明:本站内容仅供参考,不作为设计及确切依据!想了解更多,可立即进入Bbs提问