MYSQL中正则表达式检索数据库
1、MySQL中使用通配符检索数据库,之外还可以使用正则表达式来检索数据。
使用通配符 ‘_’ 和 '%'的区别如下, 使用通配符的技巧:一般的来说 通配符可以处理数据,但是消耗内存较大, 所以在使用的时候要注意技巧。
- 不要过度的使用通配符 如果其他操作系统能够达到形同的效果,使用其他的方法。
- 不要将通配符使用在搜索模式的开始处,不然搜索很缓慢。
- 注意通配符的位置,放错地方会检索的数据完全的不同

2、使用正则表达式进行搜索数据库
正则表达式 是用来匹配文本的特殊的字符串,这里正则表达式的语法不再重复(MySQL仅支持多数正则表达式实现的一个很小的子集)
REGEXP 类似 之前通配符的 like

下面的正则表达式中的 . 表示任意一个字符

下面比较下like 和REGEXP 之间的差别,通过语句之间的差异来比对:从下面的两条执行的语句来看,第一条不会反悔结果,但是使用正则表达的会返回结果。 因为LIKE 匹配的是整个列,如果被匹配的文本在列值中出现,like将不会找到,相应的行也不会返回结构除非使用通配符。 但是REGEXP 在列值内进行匹配,如果匹配的文本在列值中出现,REGEXP则会找打,相应的行会被返回。

除此之为傲REGEXP 也可以像like一样匹配整个列值, 可以使用 ^ 和$ 定位符即可。 在MySQL中的正则表达式不区分大小写,如果要区分大小写可以使用关键字 BINARY eg: where prod_name REGEXP BINARY 'JetPack .000' 。
其二 OR的匹配: 搜索两个串之一或者另一个串,使用 | ,| 为正则表达式OR的操作符,表示匹配其中的之一。1000,2000都匹配所有都返回。从功能是上看,类似于select语句中使用的or 语句。

匹配几个字符之一,可以使用 [] 俩进行限制。【123】表示定义一组字符,他的意思是匹配1,2,或者3 ,因此1 ton , 2ton ,返回。


为了简化这种类型的集合,可以使用定义一个范围,[0123456789] 表示匹配0-9之间的数字,或者使用[0-9]功能类似 ,或者也可以是字母[a-z]

匹配特殊字符: 匹配 . 其中 .表示任意字符,所有与之匹配的所有字符都被检索出来

为了匹配特字符,我们使用\\ 为前导 符号, \\ -表示查找 -, \\. 表示查找 . 下面反馈的数据才是我们正在期望输出的,这种处理方式叫做转义。除此之外还有 其他的表达式。
\\f 表示换页 \\n 表示换行 \\r 表示回车 \\t 表示制表符 \\v 表示纵向制表符

匹配字符类, MySQL中定义了字符类。这个下去自己查找。
匹配多个实例: 目前为止正则表达式视图匹配单次出现,如果存在一个匹配该行被检索出来,如果没有则检索不出任何行,但有时候需要对匹配的数目进行严格的控制,比方说你可能需要查找所有的数字,不管包含多少数字。



[:digit:]匹配任意数字,因为他是数字的一个集合。{4} 表示确切的要求他前面的字符出现4次 ,所以 [[:digig:]]{4} 匹配连载一起的任意四位数字
但是在编写正则表达式的时候每一种过滤都可以使用不同的方法来实现。
最后看 定位符的作用。为了匹配特定位置的文本,需要使用定位符:
^ 表示文本的开始位置 $ 表示文本的结尾位置 [[:<:]] 词的开始 [[:>:]] 词的结尾位置


MYSQL中正则表达式检索数据库的更多相关文章
- MySQL中的information_schema数据库表说明
MySQL 中的 information_schema 数据库 版权声明:https://blog.csdn.net/kikajack/article/details/80065753 1. 概述 ...
- mysql中正则表达式的使用
mysql中正则表达式的性能要高于like,所以这里总结一下正则表达式的使用. 正则表达式的模式及其含义: 下面举例说明其用法: 建表student: create table student(id ...
- MySQL 中的默认数据库介绍
MySQL 中的默认数据库介绍:https://dataedo.com/kb/databases/mysql/default-databases-schemas 默认数据库 官方文档 informat ...
- MySQL中的information_schema数据库详解
information_schema数据库是MySQL自带的,它提供了访问数据库元数据的方式.什么是元数据呢?元数据是关于数据的数据,如数据库名或表名,列的数据类型,或访问权限等.有些时候用于表述该信 ...
- EF Core使用CodeFirst在MySql中创建新数据库以及已有的Mysql数据库如何使用DB First生成域模型
官方教程:https://docs.microsoft.com/en-us/aspnet/core/data/?view=aspnetcore-2.1 使用EF CodeFirst在MySql中创建新 ...
- 关于MYSQL中like 检索汉字问题。
mysql中like’中国‘查询不出来结果 如果 like‘zg’就看查询出来结果. 查询了半天是由于mysql中编码的原因 解决办法: 进入mysql 输入命令:show variables lik ...
- MySQL中正则表达式
正则表达式是用来匹配文本的特殊的串(字符集合),将一个模式(正则表达式)与一个文本串进行比较 从文本文件中提取电话号码 查找名字中间带有数字的文件 文本块中重复出现的单词 替换页面的URL为这些URL ...
- Mysql 中如何创建数据库和数据表
这里的数据库为:user 数据表为 aaa mysql –uroot –p 进入mysql create database user; 创建数据 ...
- MySQL中关于主从数据库同步延迟的问题解决
MySQL的主从同步是一个很成熟的架构,优点为:①在从服务器可以执行查询工作(即我们常说的读功能),降低主服务器压力;②在从主服务器进行备份,避免备份期间影响主服务器服务;③当主服务器出现问题时,可以 ...
- MySQL 中的 information_schema 数据库
1. 概述 information_schema 数据库跟 performance_schema 一样,都是 MySQL 自带的信息数据库.其中 performance_schema 用于性能分析,而 ...
随机推荐
- SignalR系列文章01---MVC项目中创建demo
1. 新建mvc项目,引入指定的nuget包 2. 新增加一个集成器类添加如下的代码 /// <summary> /// 供客户端调用的服务器端代码 /// </summary& ...
- SQL 训练题目
title: SQL 训练题目 date: 2023-7-15 01:45:50 tags: - SQL 训练 一. 查询 "01" 课程比 "02" 课程成绩 ...
- 15.6寸不到1kg!LG Gram超轻薄本发布:13代酷睿加持
出道就以轻薄为主要卖点的LG Gram系列笔记本产品,在今年CES 2023上也迎来更新. 隶属于全新LG Gram UltraSlim产品线的15.6寸新品(15Z90RT),机身重量仅998g,厚 ...
- php批量更新多条数据
/** * @param $table 表名 * @param array $multipleData 拼接的批量更新的数组格式: * $students = [['id' => 1, 'cit ...
- 洛谷P1249最大乘积,数论找规律
这道题是数论加高精度,高精度倒好说,就是高精度乘法实现,模拟列竖式乘法,但是找出要乘的这几个数实属不容易,没学过数论,只能从题解中学怎么找规律这里引用一下洛谷题解区赞数最高的题解 不知道大家看其他的题 ...
- 安装DNS服务
实验介绍: DNS的作用 DNS中文名为域名系统 它能实现域名与IP地址的互相转换 域名的命名 www.cnblogs.com 其中.com是网站是顶级域名,.cnblogs是博客园是二级域名,www ...
- Hadoop相关面试题
1.简答说一下hadoop的map-reduce编程模型 首先map task会从本地文件系统读取数据,转换成key-value形式的键值对集合 使用的是hadoop内置的数据类型,比如longwri ...
- ES6学习 第七章 函数的扩展
前言 本章介绍函数的扩展.有些不常用的知识了解即可. 本章原文链接:函数的扩展. 函数参数的默认值 ES6 允许为函数的参数设置默认值,即直接写在参数定义的后面. 当函数形参没有被赋值时,才会将默认值 ...
- DS18B20数字温度计 (二) 测温, ROM和CRC算法
目录 DS18B20数字温度计 (一) 电气特性, 寄生供电模式和远距离接线 DS18B20数字温度计 (二) 测温, ROM和CRC算法 DS18B20数字温度计 (三) 1-WIRE总线 ROM搜 ...
- [技术选型与调研] 流程引擎(工作流引擎|BPM引擎):Activiti、Flowable、Camunda
1 概述:流程与流程引擎 低代码平台.办公自动化(OA).BPM平台.工作流系统均需要[流程引擎]功能 BPM平台与工作流系统的区别,参见本文档:3.2 章节 流程引擎是任务分配软件(例如业务流程管理 ...