SQL模糊查询排序问题

来源:互联网 发布:武汉大学网络教学平台 编辑:程序博客网 时间:2024/05/22 16:27

需求描述

  • 查询表中名字带指定关键字的数据
  • 完全匹配放在第一位
  • 前匹配放在第二位
  • 末尾匹配放在第三位
  • 中间匹配放在第四位

建表

DROP TABLE IF EXISTS `t_user`;CREATE TABLE `t_user` (  `id` varchar(20) NOT NULL,  `name` varchar(20) DEFAULT NULL,  `password` varchar(20) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

初始数据

insert into t_user values(1,'汪峰','888888');insert into t_user values(2,'王汪峰','888888');insert into t_user values(3,'汪峰峰','888888');insert into t_user values(4,'欧阳汪峰','888888');insert into t_user values(5,'王汪峰峰','888888');

直接like查询

select * from t_user where name like '%汪峰%';

结果为:
like
可以发现,“汪峰峰”并没有排列在“王汪峰”前面

使用case when进行辅助排序

select * from t_user f where f.name like '%汪峰%' order by (casewhen f.name = '汪峰' then 1 when f.name like '汪峰%' then 2when f.name like '%汪峰' then 3when f.name like '%汪峰%' then 4  else 0end ) limit 0,50;

查询结果为:
case when
等于说额外添加了一个虚拟列,来辅助进行排序;
首先匹配完全==的,然后再按照规则匹配下一条数据,就能得到我们想要的结果了。

原创粉丝点击