• 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}$';

  • 相关阅读:
    JSONObject.fromObject--JSON与对象的转换
    oracle 10g学习6
    eclipse中导入svn的三种方式
    网络方面知识收集
    oracle 10g学习之分组函数
    求m阶矩阵的n次幂
    分解质因数
    字符串对比
    十六进制转十进制
    十进制转化十六进制
  • 原文地址:https://www.cnblogs.com/cnbing/p/3237547.html
Copyright © 2020-2023  润新知