MySQL全文索引的使用

来源:这里教程网 时间:2026-03-01 16:13:03 作者:

自己原文公众号: https://mp.weixin.qq.com/s/BhUH6rcQHNGpW7_WQEnScA

有开发求助,要查公司,但是公司带括号。括号可能是全角的也可能是半角的。这种问题不是第一次见了,见得太多了。大家似乎习惯是输入时候是任意的,只是查询时候来做区分。其实这是不对的。就像垃圾分类是在小区垃圾桶做?还是在垃圾处理厂最后一道手续的时候做?显然前期分类比较合适。

    我们以前做公安系统,录入路口、路段、坐标等等都是有严格规定。所以在页面上你可以随意输入,但是输入框内会自动给你全部转换成统一格式,以便统一存储。现在发现我的第一个公司的开发团队的水平是我经历过最高的。从设计到实现,不仅规范而且高效。原因是都是70、80的为开发主力或者开发负责人。

说真的看到这个SQL已经没有调试的想法了,第一个感觉就是重写吧。前面不规范欠的债。
解决问题的方法要改变一下:
做个demo样品。

mysql> create table a (id int auto_increment primary key,user varchar(20), fulltext(user) with parser ngram);

Query OK, 0 rows affected (0.20 sec)

模拟数据以后是这样的:(数据是随便编的不一定有这些公司,主要是为了全角和半角的括号)

如果我们命令是

select * from a where user like '%网易%';

查出数据过多。

如果命令是select * from a where user like '%广州%';

查出数据有不符合的。

既不能多也不能少,而且要处理掉括号。

SQL应该这样写:

select * from a where match(user) against ('+网易 +广州' IN BOOLEAN MODE);

嗯,符合要求。

    Oracle下的实现请看下一篇。PostgreSQL的也有,只是不够熟练,需要再尝试一下,陆续推出。

相关推荐