我们在使用 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语句,那么很有可能无法再第一页获取到张三这条记录。
也就引出了今天的问题,如何在模糊查询条件下,让返回结果按照匹配度(相似度)进行进行排序,从而让最匹配的那条记录排在最前面。
问题分析
首先,我们需要定位一下问题原因,为什么最匹配的那条记录被排到了最后面?
这其实