我们在使用 MySQL 进行模糊查询的时候,受到默认排序的影响,我们会发现与查询关键字相似的记录有时候并没有排到最前面。
如 :
CREATE TABLE user(
id BIGINT(11) AUTO_INCREMENT PRIMARY KEY,
name varchar(255)
)engine=InnoDB,DEFAULT CHARSET=UTF8;
INSERT INTO user(name) values("F张三"),("E张三"),("D张三"),("C张三"),("B张三"),("A张三"),("AAA张三"),("张三"),("李四"),("王五");
对上述数据以张三为关键字进行模糊查询后,会发现查询结果如下:
SELECT * FROM user WHERE name LIKE "%张三%";

可以看到,与张三最相似的一条记录被排序到了最后面,如果我们使用了 LIMIT语句,那么很有可能无法再第一页获取到张三这条记录。
也就引出了今天的问题,如何在模糊查询条件下,让返回结果按照匹配度(相似度)进行进行排序,从而让最匹配的那条记录排在最前面。
问题分析
首先,我们需要定位一下问题原因,为什么最匹配的那条记录被排到了最后面?
这其实是与SELECT 的默认排序规则有关,当我们使用 SELECT 进行查询而没有指定 ORDER BY的时候,MySQL其实是按照id 进行升序排序的,因为 id作为主键索引通过它根本不需要排序,同时每次返回的结果顺序也完全相同。也就是说id = 7 的张三记录之所以被排在最后面是因为它是在最后被插入的,即使它是最张三的张三也要讲个先来后到。
在一些情况下我们的排序是按

最低0.47元/天 解锁文章
260

被折叠的 条评论
为什么被折叠?



