zoukankan      html  css  js  c++  java
  • MySQL WHERE子句内使用正则表达式搜索

    正则表达式之初见

    下面的语法检索列prod_name包含文本1000的所有行

    SELECT * FROM products WHERE prod_name REGEXP '1000';

    这里写图片描述
    使用正则表达式语言中一个特殊的字符.,它表示匹配任意一个字符

    SELECT * FROM products WHERE prod_name REGEXP '.000';

    这里写图片描述


    SELECT * FROM products WHERE prod_name LIKE '1000';SELECT * FROM products WHERE prod_name REGEXP '1000';

    执行上面两条语句,会发现第一条语句不返回数据,而第二条语句会返回一条。
    这里写图片描述
    LIKE匹配整个列。如果被匹配的文本在列值中未出现,LIKE将不会找到它,相应的行也不被返回(除非使用通配符)。而REGEXP在列值内进行匹配,如果被匹配的文本在列值中出现,REGEXP将会找到它,相应的行将被返回。REGEXP也能匹配整个列(和LIKE相同的作用)使用^和$定位符即可。


    MySQL中正则表达式匹配不区分大小写(即,大写和小写都匹配)。为区分小写,可用BINARY关键字。
    这里写图片描述

    正则表达式之匹配特殊字符

    正则表达式语言由具有特定含义的特殊字符构成。如果需要匹配特殊字符,应该怎么办,例如匹配 . 的值,需要转义,
    需要用为前导。\表示查找,.表示查找.。
    这里写图片描述
    多数正则表达式实现使用单个反斜杠转义特殊字符,以便能使用这些字符本身。但MySQL要求两个反斜杠(MySQL自己解释一个,正则表达式库解释另一个)。

    正则表达式之定位元字符

    ^表示文本的开始
    $表示文本的结尾
    [[:<:]]表示词的开始
    [[:>:]]表示词的结尾
    例如匹配文本以1开头的文本
    这里写图片描述

  • 相关阅读:
    HTML5 跨文档消息传输
    Cordova 本地项目创建方法
    远程登录协议
    Linux mii-tool命令
    Linux ethtool命令
    Linux内核阅读相关
    C语言介绍
    Proc-fs 编程
    Linux syslog介绍
    Mpich编程
  • 原文地址:https://www.cnblogs.com/aotemanzhifu/p/9192380.html
Copyright © 2011-2022 走看看