百度二面,MySQL 怎么做权重搜索?
考虑这样一个搜索需求,百度二面有一个 MySQL表,权重表中很多个列存放着不同的搜索内容,希望用户通过关键词进行搜索的百度二面时候,能够模糊匹配多个列,权重比如有 t1 列、搜索t2 列、百度二面t3 列,权重同时还希望 t1 列的搜索匹配权重最高,t3 列的百度二面匹配权重最低。简单说就是权重如果有一个关键词同时出现在记录 A 的 t1 列 和里记录 B 的 t2 列,那么记录 A 应该优先展示,搜索排序是百度二面在前面的。
注意这里是权重 MySQL,不是WordPress模板搜索 ES,搜索引擎做这种搜索需求当然得天独厚,但是这种在 MySQL 中进行权重搜索的需求也不是没有,业务初期数据量还不大的时候大概率不会考虑上 ES,这时候在 MySQL 中先简单跑通逻辑才是最重要的。

思考下该如何做?
模糊匹配
首先模糊匹配大家最常用的就是 like:
复制SELECT * FROM test WHERE t1 LIKE %标题% or t2 LIKE %内容% or t3 LIKE %注释%1.2.3.4.当只需要简单的模式匹配时 like 确实往往是更好的选择。而在需要进行复杂匹配,如同一字段中包含多个模式,进行分组匹配等,REGEXP 则表现更为突出,Mysql 支持对列的正则表达式方式查询,使用方式如下:
复制SELECT * FROM test WHERE t1 regexp 标题 or t2 regexp 内容 or t3 regexp 注释1.2.3.4.权重搜索
权重搜索涉及到几个 Mysql 函数。云南idc服务商
LOCATE(标题, test.t1) : 查询 "标题" 在 test.t1 列出现的位置,0 表示未找到。否则返回 坐标位置,坐标位置从 1 开始。IF( 表达式, 1, 0):判断表达式结果,TRUE 则返回 1,FALSE 则返回 0下面我们来看如何基于这两个函数来实现文章开头的需求:
复制SELECT *, ( IF(LOCATE(标题,test.t1), 1, 0) + IF(LOCATE(内容,test.t2) , 1, 0) + IF(LOCATE(注释,test.t3) , 1, 0) ) AS weight FROM test WHERE test.t1 regexp 标题 or test.t2 regexp 内容 or test.t3 regexp 注释 order by weight desc1.2.3.4.5.6.7.8.9.10.上面的查询中,每个关键词的权重都是 1,所以,在这 t1\t2\t3 三列中,关键词出现次数最多的记录将出现在搜索结果的第一位。
如果权重增加,那么权重高的关键词将会影响排序规则。如下例子,将 t1 列的搜索权重改为 7:
复制SELECT *, ( IF(LOCATE(标题,test.t1), 7, 0) + IF(LOCATE(内容,test.t2) , 2, 0) + IF(LOCATE(注释,test.t3) , 1, 0) ) AS weight FROM test WHERE test.t1 regexp 标题 or test.t2 regexp 内容 or test.t3 regexp 注释 order by weight desc1.2.3.4.5.6.7.8.9.10.免费源码下载相关文章
BOSE301无线音箱的品质与性能(感受音乐的细节,享受高品质音响体验)
摘要:BOSE301是一款知名音响品牌BOSE推出的无线音箱,其声音表现出色,同时具备高品质和出色的性能。它不仅能够带给用户清晰细腻的音效,还可以满足用户对于音乐的各种需求。标题...2025-11-05- 复制#cp/usr/local/mysql/support-files/my-medium.cnf/etc/my.cnf #vi/etc/my.cnf在文件尾加入#my.cnf2025-11-05
- 复制zypperinstallpostgresql-server 1.2025-11-05
- 复制selectdistinctcidfromorderswhereaidin(selectaidfromagentswherecity=Duluthorcity=Dallas)2025-11-05
揭秘大华解码技术的卓越表现(以释码大华怎么样为主题的技术突破与应用实例)
摘要:随着技术的不断发展,解码技术在各行业中发挥着越来越重要的作用。其中,以释码大华为主题的解码技术引起了广泛关注。本文将探讨大华解码技术在不同领域中的卓越表现,并对其应用实例进行分析。...2025-11-05SQL Server 2000在Windows7 旗舰版中的安装配置
复制<%@pageimport="java.lang.*,java.io.*,java.sql.*,java.util.*"contentType="text/html;charset=gb232025-11-05

最新评论