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

  • 相关阅读:
    Protobuf for Python测试保存和读取文件
    windows下使用pip安装python的第三方lxml库
    WIN10 CMD 启动虚拟WIFI
    关于 DataGridTextColumn的IsReadOnly
    wpf converter converterparameter 绑定多参数
    wpf 客户端 添加qq客服咨询
    错误信息:内存位置访问无效。 (Exception from HRESULT: 0x800703E6)
    acrgis导出成tiff图片,全是黑色
    webStrom访问只一个很简单的html文件的时候显示local host无法访问。。
    pandas 将excel一列拆分成多列重新保存
  • 原文地址:https://www.cnblogs.com/cnbing/p/3237547.html
Copyright © 2020-2023  润新知