zoukankan      html  css  js  c++  java
  • MySQL九读书笔记 字符串模式匹配

        当我们使用查询,条件常常会遇到模糊查询。的模糊查询相关的字符串模式匹配。

        这里,主要约两:标准SQL模式匹配、扩展正则表达式模式匹配。

        一、标准的SQL模式匹配

        SQL的模式匹配同意你使用“_”匹配不论什么单个字符,而“%”匹配随意数目字符(包含零个字符)。

    在MySQL中。SQL的模式缺省是忽略大写和小写的。以下显示一些样例。注意在你

    使用SQL模式时,你不能使用=或!=;而使用LIKE或NOT LIKE比較操作符。

        为了找出包括正好5个字符的名字,使用“_”模式字符,能够这样写:

        SELECT * FROM student WHERE name LIKE "_ _ _ _ _";(空格是没有的。仅仅是为了演示方便)

        “%”匹配与oracle一样一样的。此处省略。

        二、扩展正則表達式模式匹配

        与Java或javascript正則表達式的使用方法类似。

        由MySQL提供的模式匹配的其它类型是使用扩展正則表達式。当你对这类模式进行匹配測试时,使用REGEXPNOT REGEXP操作符(或RLIKENOT RLIKE。它们是

    同义词)。


        扩展正則表達式的一些字符是:
        “.”匹配不论什么单个的字符。
        一个字符类“[...]”匹配在方括号内的不论什么字符。比如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的一个范围,使用一个“-”。

    “[a-z]”匹配不论什么小写字母,而“[0-9]”匹配不论什么数字。
        “ * ”匹配零个或多个在它前面的东西。

    比如,“x*”匹配不论什么数量的“x”字符,“[0-9]*”匹配的不论什么数量的数字,而“.*”匹配不论什么数量的不论什么东西。


        正則表達式是区分大写和小写的,可是假设你希望,你能使用一个字符类匹配两种写法。比如,“[aA]”匹配小写或大写的“a”而“[a-zA-Z]”匹配两种写法的不论什么字母。


        假设它出如今被測试值的不论什么地方。模式就匹配(仅仅要他们匹配整个值,SQL模式匹配)。
        为了定位一个模式以便它必须匹配被測试值的開始或结尾,在模式開始处使用“^”或在模式的结尾用“$”

        下面为简单演示样例:

        为了找出以“b”开头的名字,使用“^”匹配名字的開始而且“[bB]”匹配小写或大写的“b”:
        mysql> SELECT * FROM student WHERE name REGEXP "^[bB]";
        +--------+--------+---------+------+------------+------------+
        | name | owner | species | sex | birth | death |
        +--------+--------+---------+------+------------+------------+
        | Buffy | Harold | dog | f | 1989-05-13 | NULL |
        | Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
        +--------+--------+---------+------+------------+------------+
        为了找出以“fy”结尾的名字,使用“$”匹配名字的结尾:
        mysql> SELECT * FROM student WHERE name REGEXP "fy$";
        +--------+--------+---------+------+------------+-------+
        | name | owner | species | sex | birth | death |
        +--------+--------+---------+------+------------+-------+
        | Fluffy | Harold | cat | f | 1993-02-04 | NULL |
        | Buffy | Harold | dog | f | 1989-05-13 | NULL |
        +--------+--------+---------+------+------------+-------+
        为了找出包括一个“w”的名字,使用“[wW]”匹配小写或大写的“w”:
        mysql> SELECT * FROM student WHERE name REGEXP "[wW]";
        +----------+-------+---------+------+------------+------------+
        | name | owner | species | sex | birth | death |
        +----------+-------+---------+------+------------+------------+
        | Claws | Gwen | cat | m | 1994-03-17 | NULL |
        | Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
        | Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |
        +----------+-------+---------+------+------------+------------+
        既然假设一个正规表达式出如今值的不论什么地方。其模式匹配了,就不必再先前的查询中在模式的双方面放置一个通配符以使得它匹配整个值。就像假设你使用了一个SQL模式那样。
        为了找出包括正好5个字符的名字。使用“^”和“$”匹配名字的開始和结尾。和5个“.”实例在两者之间:
        mysql> SELECT * FROM student WHERE name REGEXP "^.....$";
        +-------+--------+---------+------+------------+-------+
        | name | owner | species | sex | birth | death |
        +-------+--------+---------+------+------------+-------+
        | Claws | Gwen | cat | m | 1994-03-17 | NULL |
        | Buffy | Harold | dog | f | 1989-05-13 | NULL |
        +-------+--------+---------+------+------------+-------+
        你也能够使用“{n}”“反复n次”操作符重写先前的查询:
        mysql> SELECT * FROM student WHERE name REGEXP "^.{5}$";
        +-------+--------+---------+------+------------+-------+
        | name | owner | species | sex | birth | death |
        +-------+--------+---------+------+------------+-------+
        | Claws | Gwen | cat | m | 1994-03-17 | NULL |
        | Buffy | Harold | dog | f | 1989-05-13 | NULL |
        +-------+--------+---------+------+------------+-------+

    版权声明:本文博主原创文章,博客,未经同意不得转载。

  • 相关阅读:
    System.IO.StreamWriter
    C# XML
    C# 泛型
    ACM将一个十进制的数转换为一个十六进制的数输出
    ACM打扫花园问题
    ACM用N个正方体来建造金字塔问可以建造多少层
    输入一串数字找出其中缺少的最小的两个数
    高效算法——B 抄书 copying books,uva714
    暴力求解——POJ 3134Power Calculus
    暴力求解——打表,暴力
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/4885350.html
Copyright © 2011-2022 走看看