zoukankan      html  css  js  c++  java
  • mysql 正则表达式

    SQL模式匹配允许你使用“_”匹配任何单个字符,而“%”匹配任意数目字符(包括零字符)。在 MySQL中,SQL的模式默认是忽略大小写的。下面给出一些例子。注意使用SQL模
    式时,不能使用=或!=;而应使用LIKE或NOT LIKE比较操作符。
       
    1.要想找出以“b”开头的id:
    select * from userinfo where userid like 'b%';
    2.要想找出以“b”结尾的id
    select * from userinfo where userid like '%b';
    3.要想找出包含“b”的id:
    select * from userinfo where userid like '%b%';
    4.要想找出正好包含5个字符的名字,使用“_”模式字符:
    select * from userinfo where userid like '_____';
    由MySQL提供的模式匹配的其它类型是使用扩展正则表达式。当你对这类模式进行匹配测试时,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它们是同义词)。
    扩展正则表达式的一些字符是:
    ·         ‘.’匹配任何单个的字符。
    ·         字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0
    -9]”匹配任何数字。
    ·         “ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。
    如果REGEXP模式与被测试值的任何地方匹配,模式就匹配(这不同于LIKE模式匹配,只有与整个值匹配,模式才匹配)。
    为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。
    5.要想找出以“b”或“B”开头的id:
    select * from userinfo where userid regexp '^b';
    6.想找出以“B”开头的id
    select * from userinfo where userid regexp binary '^B';
    7.找出数字开头,数字结尾的id
    select * from userinfo where userid regexp '^[0-9]*[0-9]$';
    8.包含字母“b”的id
    select * from userinfo where userid regexp 'b';
    9.找出包含正好5个字符的名字
    select * from userinfo where userid regexp '^.....$';
    10.也可以使用“{n}”“重复n次”操作符重写前面的查询:
    select * from userinfo where userid regexp '^.{5}$';
    11.字母开头的userid
    select * from userinfo where userid regexp '^[a-z]';
    12.字母开头字符数为6的userid
    select * from userinfo where userid regexp '^[a-z].{5}$';

  • 相关阅读:
    并发编程之线程进阶
    并发编程之线程
    进程间通信(队列和管道)
    在python程序中的进程操作
    操作系统之进程
    网络编程之黏包
    树莓派 websocket 控制LED
    lua 调用 C -- 实例 C函数作为应用程序的一部分
    linux 环境下进程什么时候会被 killed掉
    STM32 + cJSON 死机问题解决
  • 原文地址:https://www.cnblogs.com/cnbing/p/3237547.html
Copyright © 2011-2022 走看看