myysql的正则表达式

上周遇见一个需求,有这样一棵树:

点击上级,展现所有子集,点击集团,显示所有产线(例子)

这个时候有两种方式:

添加产线时,将集团、事业部、公司、车间的id存起来。

然后点击查询时,将不同的id带入。

这样做的缺点就是,查询会很麻烦,区分查询。

另一种是:

一个treePath字段,存放树路径id:

集团id,事业部id,公司id,车间id,产线id

例子:点击集团时,将集团id和treePath进行in比较。如果包含,就说明是这个集团的数据。

sql 复制代码
 CONCAT (',',tree_path,',' ) LIKE CONCAT( '%,',集团id,',%' )

先将源数据加一个左右各一个逗号,保证不会出现这种情况!!!

treePath:1001,221,333

集团id:10

挖槽,直接GG

1001也符合!!

所以我们左右各加一个逗号变成:

treePath:,1001,221,333,

集团id:,10,

哈哈哈哈哈哈哈,这样就不会出现那种情况了,我真是天才啊!

用正则就是这样:

sql 复制代码
CONCAT (',',tree_path,',') REGEXP ',(集团id),'

话不多说,直接上态度:

sql 复制代码
select *from `user` as u where u.`name` REGEXP 'ab?c';-- c出现0次或者1次

select *from `user` as u where u.`name` REGEXP 's*c';-- s出现0次或者多次

select *from `user` as u where u.`name` REGEXP 'ab+c';-- b出现1次以上的字符

select *from `user` as u where u.`name` REGEXP 'a.c';-- 以a开始,c结束。.可以代表无数个,相当于模糊查询的%

select *from `user` as u where u.`name` REGEXP 'b{2,}';-- b连续出现2次以上

select *from `user` as u where u.`name` REGEXP 'b{2}';-- b连续出现2次

select *from `user` as u where u.`name` REGEXP 'b{2,3}';-- b连续出现2-3次

select *from `user` as u where u.`name` REGEXP 'b{2}|a{3}';-- b连续出现2次或者a连续出现3次

select *from `user` as u where u.`name` REGEXP '[acs]';-- 包含这三个字母组成

select *from `user` as u where u.`name` REGEXP '[a-b]';-- 包含a-c组成

select *from `user` as u where u.`name` REGEXP '^a';-- 以a开头
 
select *from `user` as u where u.`name` REGEXP 's$';-- 以c结尾
相关推荐
TDengine (老段)9 小时前
TDengine 扫描算子 — TableScan、TagScan 与下推优化
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
放下华子我只抽RuiKe59 小时前
FastAPI 全栈后端(三):数据库与 ORM
前端·数据库·react.js·oracle·性能优化·前端框架·fastapi
源图客9 小时前
境外电商 - 龙虾智能体-综合选品推荐报告
开发语言·javascript·ecmascript
磊 子10 小时前
C++设计模式
javascript·c++·设计模式
梵得儿SHI10 小时前
Vue 项目实战与性能优化全攻略:从代码、渲染到首屏,一站式解决卡顿慢加载
前端·vue.js·性能优化·vite·前端面试·前端优化·首屏优化
ShyanZh10 小时前
【skill】HTML PPT Skill:用 Claude Code 一句话生成专业演示文稿
前端·ai·html·powerpoint·skill
BAGAE10 小时前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
zh_xuan10 小时前
Android导出并查看数据库
数据库·sqlite
AI视觉网奇10 小时前
three教学 3d资产拼接源代码
前端·css·css3
小短腿的代码世界10 小时前
Qt定时器高精度架构:从QTimer源码到纳秒级定时调度
数据库·qt·架构