
今晚看书回顾 MySQL 的基础知识,看到正则表达式一块儿,才发现自己从来没有使用过正则表达式,不论是个人项目还是公司项目,感觉没怎么见过使用正则表达式来查询数据的。
搜索引擎搜了一下,使用正则似乎比 LIKE 查询是要快一点点的,不过自己未验证,不敢笃定。
不知各位平时有过使用经验吗?
1 hsuyeung OP 刚刚又看到了 SOUNDEX() 函数,以前的确没注意到过,感觉挺有趣。 |
2 Jface 2022-08-11 23:51:54 +08:00 via iPhone 有的,很多业务需求匹配需要正则来匹配,基本就是关键词匹配,条件判断等等 |
3 moen 2022-08-12 00:03:21 +08:00 会用,因为平时习惯用正则,相对地写起来更舒服。而 LIKE 匹配和正则匹配本质上都是个状态机,相同的匹配逻辑下一般不存在什么性能差异 |
4 saberlong 2022-08-12 08:06:28 +08:00 via Android 很少用,要用也是带其它条件字段将数据缩减到足够小的范围。正则走不了索引。而通常做查询时,先考虑走什么索引。 |
5 shakoon 2022-08-12 08:20:29 +08:00 偶尔会用,因为有些条件用 sql 实在写不出来,或者强行写需要嵌套很多分支调用很多函数,性价比太低 |
6 xaplux 2022-08-12 08:41:11 +08:00 不建议用,这玩意不用想也知道性能不咋地,如果用到了可以考虑是不是需要上 ES |
7 xboxv 2022-08-12 08:47:50 +08:00 via Android 字段套了函数没法使用索引 |
8 siweipancc 2022-08-12 08:58:41 +08:00 via iPhone 然后触发扫表…… |
9 L0L 2022-08-12 09:35:54 +08:00 非特殊场景别用,徒增数据库压力,数据库就应该做些简单的事情。 |
10 kinXdle 2022-08-12 10:05:59 +08:00 不会,like 效率高多了 |
11 stevenbipt 2022-08-12 17:50:25 +08:00 like 有的场景能用上索引,但是正则在文档上说了一定走不上索引,触发扫表的一般都要慎重考虑 |
12 BunnyEatingGrass 2022-08-12 19:23:19 +08:00 有需求就会用的,还有 like 的特殊用法,不过现在基本都不写 SQL 了,SQL 主要用在做报表部分吧? |