大家平时写 SQL 会用正则表达式吗?

2022-08-11 22:50:26 +08:00
 hsuyeung

今晚看书回顾 MySQL 的基础知识,看到正则表达式一块儿,才发现自己从来没有使用过正则表达式,不论是个人项目还是公司项目,感觉没怎么见过使用正则表达式来查询数据的。

搜索引擎搜了一下,使用正则似乎比 LIKE 查询是要快一点点的,不过自己未验证,不敢笃定。

不知各位平时有过使用经验吗?

2532 次点击
所在节点    程序员
12 条回复
hsuyeung
2022-08-11 23:14:02 +08:00
刚刚又看到了 SOUNDEX() 函数,以前的确没注意到过,感觉挺有趣。
Jface
2022-08-11 23:51:54 +08:00
有的,很多业务需求匹配需要正则来匹配,基本就是关键词匹配,条件判断等等
moen
2022-08-12 00:03:21 +08:00
会用,因为平时习惯用正则,相对地写起来更舒服。而 LIKE 匹配和正则匹配本质上都是个状态机,相同的匹配逻辑下一般不存在什么性能差异
saberlong
2022-08-12 08:06:28 +08:00
很少用,要用也是带其它条件字段将数据缩减到足够小的范围。正则走不了索引。而通常做查询时,先考虑走什么索引。
shakoon
2022-08-12 08:20:29 +08:00
偶尔会用,因为有些条件用 sql 实在写不出来,或者强行写需要嵌套很多分支调用很多函数,性价比太低
xaplux
2022-08-12 08:41:11 +08:00
不建议用,这玩意不用想也知道性能不咋地,如果用到了可以考虑是不是需要上 ES
xboxv
2022-08-12 08:47:50 +08:00
字段套了函数没法使用索引
siweipancc
2022-08-12 08:58:41 +08:00
然后触发扫表……
L0L
2022-08-12 09:35:54 +08:00
非特殊场景别用,徒增数据库压力,数据库就应该做些简单的事情。
kinXdle
2022-08-12 10:05:59 +08:00
不会,like 效率高多了
stevenbipt
2022-08-12 17:50:25 +08:00
like 有的场景能用上索引,但是正则在文档上说了一定走不上索引,触发扫表的一般都要慎重考虑
BunnyEatingGrass
2022-08-12 19:23:19 +08:00
有需求就会用的,还有 like 的特殊用法,不过现在基本都不写 SQL 了,SQL 主要用在做报表部分吧?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/872306

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX