有开发求助,要查公司,但是公司带括号。括号可能是全角的也可能是半角的。这种问题不是第一次见了,见得太多了。大家似乎习惯是输入时候是任意的,只是查询时候来做区分。其实这是不对的。就像垃圾分类是在小区垃圾桶做?还是在垃圾处理厂最后一道手续的时候做?显然前期分类比较合适。
我们以前做公安系统,录入路口、路段、坐标等等都是有严格规定。所以在页面上你可以随意输入,但是输入框内会自动给你全部转换成统一格式,以便统一存储。现在发现我的第一个公司的开发团队的水平是我经历过最高的。从设计到实现,不仅规范而且高效。原因是都是70、80的为开发主力或者开发负责人。
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的也有,只是不够熟练,需要再尝试一下,陆续推出。
文章转载自四海内皆兄弟,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2872次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
838次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
485次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
424次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
371次阅读
2025-04-15 14:48:05
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
274次阅读
2025-04-15 15:27:53
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
272次阅读
2025-04-30 17:37:37
SQL优化 - explain查看SQL执行计划(下)
金同学
261次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
241次阅读
2025-04-30 12:17:54
MySQL 8.4 新特性深度解析:功能增强、废弃项与移除项全指南
JiekeXu
226次阅读
2025-04-18 20:21:32