广告
返回顶部
首页 > 资讯 > 数据库 >数据库MySQL 通配符与模式匹配正则表达式
  • 839
分享到

数据库MySQL 通配符与模式匹配正则表达式

2024-04-02 19:04:59 839人浏览 八月长安
摘要

今天一个同事说他写了一个sql语句查询没有结果,他是这样写的 SELECT * FROM Persons WHERE City&n

今天一个同事说他写了一个sql语句查询没有结果,他是这样写的

 SELECT * FROM Persons WHERE City LIKE '[BLN]%'

数据库MySQL 通配符与模式匹配正则表达式

数据库MySQL 通配符与模式匹配正则表达式

数据库MySQL 通配符与模式匹配正则表达式


那么就再理一下:

SQL通配符是使用特殊字符或语法拼写,用来执行模糊搜索指令的语句。查询数据库中的数据时,sql通配符可以替代一个或多个字符。使用是必须与 LIKE 运算符一起使用。在SQL中可以使用的通配符有:

通配符
说明
%

替代一个或多个字符

-仅替代一个字符
[charlist]字符列中的任何一个字符
[^charlist]或[!charlist]不在字符列中的任何单一字符

"%":匹配任意数目的字符(零个或多个);"_":匹配任何单个字符;

在使用通配符时 可以用 LIKE或NOT LIKE 比较操作符,而不能用 = 或 !=

以user表为例:

查询以a结尾的记录:select * from user where username like '%a';   

查询以a开头的用户名:select * from user where username like 'a%';

查询不是以a开头的用户名:select * from user where username like 'a%';

查询包含a的用户名:select * from user where username like '%a%';

查询有两个字符的用户名:select * from user where username like '__';


重点在这里:

Mysql模式匹配的其他类型是使用扩展正则表达式,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,之后遇到Hive可以自己查下LIKE 、RLIKE)。 


扩展正则表达式的一些字符是: 
"."  匹配任何单个的字符,一个字符类“[...]”匹配方括号内的任何字符如,"[abc]" 匹配"a"、"b"或"c"。为了命名字符的一个范围,使用一个连接符"-" 。"[a-z]" 匹配任何小写字母,而"[0-9]"匹配任何数字。 
"* "  匹配零个或多个在它前面的东西。例如,"x*" 匹配任何数量的 "x" 字符,"[0-9]*" 匹配的任何数量的数字,而“.*”匹配任何数量的任何字符。

 
另外,正则表达式是区分大小写的,当然也可以使用一个字符类同事匹配大小写如,"[aA]" 匹配小写或大写的"a"而"[a-zA-Z]"匹配两种写法的任何字母。 


为定位一个模式,以便匹配目标值的开始或末尾,在模式开始处使用“^”或在模式的结尾用“$”。 下面是使用REGEXP写LIKE查询:

查询city以 “L”开头的人信息,使用“^”匹配名字的开始并且“[lL]”匹配小写或大写的“l”

select * from Persons where City REGEXP "^[lL]";

查询lastname以“sh”结尾的人,使用“$”匹配名字的结尾: 

 SELECT * FROM Persons WHERE LastName REGEXP "sh$";

查询lastname包含一个"A"的人,使用“[aA]”匹配小写或大写的“a”: 

SELECT * FROM Persons WHERE LastName REGEXP "[aA]";

查询city名恰好包含6个字符的记录,使用“^”和“$”匹配名字的开始和结尾,和6个“.”实例在两者之间: 

SELECT * FROM Persons WHERE city REGEXP "^......$";

也可以使用“{n}”“重复n次”操作符: 

SELECT * FROM pet WHERE name REGEXP "^.{6}$";

您可能感兴趣的文档:

--结束END--

本文标题: 数据库MySQL 通配符与模式匹配正则表达式

本文链接: https://www.lsjlt.com/news/42391.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 数据库MySQL 通配符与模式匹配正则表达式
    今天一个同事说他写了一个sql语句查询没有结果,他是这样写的 SELECT * FROM Persons WHERE City&n...
    99+
    2022-10-18
  • MySQL通配符与正则表达式
    通配符 通配符必须全文匹配时才为真,使用LIKE关键字 字符 示例 含义 _ "a_b" 任意一个字符"axb",其中x可以使任意字符,包括汉字 % "%a" 任意一个以a结尾的字符串 正则表达式 字符串str中有...
    99+
    2015-10-28
    MySQL通配符与正则表达式
  • MySQL通配符与正则表达式搜过滤数据详解
    目录通配符过滤通配符 %通配符 _技巧正则表达式过滤字符匹配其他字符对比正则表达式测试总结通配符过滤 通配符:用来匹配值的一部分特殊字符。 通配符可以在搜索模式中任意位置使用,并且可以使用多个通配符。 搜索模式:由字面值...
    99+
    2022-09-30
  • PostgreSQL模式匹配与正则表达式方法总结
    目录1.1 PostgreSQL中的模式匹配和正则表达式1.2 传统SQL的LIKE操作符1.3 SIMILAR TO正则表达式1.4 POSIX正则表达式1.5 模式匹配函数substring总结1.1 Postgre...
    99+
    2022-11-19
    postgresql模式匹配 postgresql正则表达式 pg正则
  • 正则表达式之字符串模式匹配实例详解
    目录前言什么是正则表达式字符范围匹配元字符多次重复匹配定位匹配贪婪模式与非贪婪模式表达式分组结语前言 今天我们来学习正则表达式,正则表达式的应用十分广泛,几乎每个涉及到交互的项目都会...
    99+
    2022-11-13
  • 正则表达式怎么匹配数字
    这篇文章给大家分享的是有关正则表达式怎么匹配数字的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。高效正则表达式匹配数字实例:^[1-9]\d*$      //匹配正整数&n...
    99+
    2023-06-17
  • 正则表达式怎么匹配多个字符
    正则表达式可以使用特殊符号来匹配多个字符:1. 使用重复符号:可以使用`*`来匹配零个或多个字符,使用`+`来匹配一个或多个字符,使用``来匹配零个或一个字符。例如,正则表达式`ab*c`可以匹配字符串"ac"、"abc"、"abbc"...
    99+
    2023-08-11
    正则表达式
  • Java正则表达式循环匹配字符串方式
    目录正则表达式循环匹配字符串Java匹配正则表达式大全我们先举个例子来看看Java匹配正则表达式匹配表达式的特殊情况正则表达式循环匹配字符串 public static void m...
    99+
    2022-11-13
  • Python正则表达式匹配字符串中的数字
    这篇文章主要介绍了Python正则表达式匹配字符串中的数字,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下1.使用“\d+”匹配全数字...
    99+
    2023-06-01
  • python中的正则表达式,贪婪匹配与非贪婪匹配方式
    目录正则表达式,贪婪匹配与非贪婪匹配正则表达式前戏. ^ $* + { }字符集[][^]分组 ()与 或 |[^]转义符 \贪婪匹配re模块下的常用方法总结正则表达式,贪婪匹配与...
    99+
    2023-01-31
    python正则表达式 python贪婪匹配 python非贪婪匹配
  • MySQL正则表达式匹配查询(含实例)
    目录一、正则表达式介绍二、使用正则表达式测试数据1.基本字符匹配2.OR匹配3.模糊匹配4.匹配范围5.匹配特殊字符6. 匹配字符类7.匹配多个实例8.定位符总结一、正则表达式介绍 ...
    99+
    2022-11-13
  • 利用正则表达式匹配浮点型数据
    目录前言:正则表达式Java代码附:正则表达式(同时匹配整型数和浮点数)总结前言: 在开发中我们常常会使用到正则表达式,但很奇怪的是,每次你在使用正则表达式的时候你都发现你不会写,不...
    99+
    2022-11-13
  • java怎么用正则表达式匹配与提取字符串
    本文小编为大家详细介绍“java怎么用正则表达式匹配与提取字符串”,内容详细,步骤清晰,细节处理妥当,希望这篇“java怎么用正则表达式匹配与提取字符串”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。首先给出一个匹...
    99+
    2023-07-02
  • java如何用正则表达式匹配与提取字符串
    java.util.regex类支持用正则表达式来匹配和提取字符串,读者可以去官网查看java.util.regex的详细使用方法。 首先给出一个匹配字符串的例子(判断line是否符...
    99+
    2022-11-13
  • 正则表达式常见的4种匹配模式小结
    目录0.写在前面1.不区分大小写模式2.点号通配模式3.多行匹配模式4.注释模式5.写在最后0.写在前面 今天一起来学习下正则中的匹配模式,所谓的匹配模式,就是指正则中的一些 改变元...
    99+
    2022-11-12
  • python正则表达式对字符串的查找匹配
    目录常用的RegEx基础语法常用的RegEx函数以下为部分示例:总结Python中的正则表达式要用到re模块,下面先介绍一下正则表达式需要用到的特殊字符和说明 常用的RegEx基础语...
    99+
    2022-11-11
  • VBS中正则表达式如何实现字符匹配
    这篇文章主要介绍了VBS中正则表达式如何实现字符匹配,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。字符匹配句点 (.) 匹配一个字符串中任何单个的打印或非打印字符,除了换行符...
    99+
    2023-06-09
  • Shell脚本中通过正则表达式匹配IP地址
    在运维场景下,我们经常需要在服务器上用正则表达式来匹配IP地址。 shell和其它编程语言一样,也可以使用正则分组捕获,不过不能使用 $1或1这样的形式来捕获分组,可以通过数组${BASH_REMATCH}...
    99+
    2022-06-04
    脚本 地址 正则表达式
  • MySQL数据库——MySQL REGEXP:正则表达式
    正则表达式主要用来查询和替换符合某个模式(规则)的文本内容。例如,从一个文件中提取电话号码,查找一篇文章中重复的单词、替换文章中的敏感语汇等,这些地方都可以使用正则表达式。正则表达式强大且灵活,常用于非常复杂的查询。 MySQL 中,使用 ...
    99+
    2023-09-01
    正则表达式 数据库 mysql
  • C#中如何使用正则表达式和字符串匹配
    C#中如何使用正则表达式和字符串匹配正则表达式是一种强大的文本处理工具,它可以帮助我们有效地在字符串中进行模式匹配和提取。在C#中,通过使用System.Text.RegularExpressions命名空间下的Regex类,我们可以轻松地...
    99+
    2023-10-22
    正则表达式 (Regex) 字符串匹配 (string matching) C#编程 (C# Programming)
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作