mysql 根据匹配度排序

1.根据输入 文本 匹配度排序

eg:输入 “长春”,全词匹配优先,然后是以“长春”开始的,然后是含有长春的

SELECT
	abbreviationname,
	belongtodescription
FROM
	ardm.com_citys _a 
WHERE
	Levels < '3' AND levels > '0' 
	AND locate( '朝阳', belongtodescription ) > 0 
ORDER BY
  # 全词匹配
	abbreviationname REGEXP '^朝阳$' DESC,
	# 以指定内容开始
	abbreviationname REGEXP '^朝阳{1,}' DESC,
	# 含有指定文本
	locate( '朝阳', belongtodescription ) DESC 

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 中可以使用 LIKE 运算符进行模糊搜索,同时可以使用 CONCAT 函数将多个字段合并成一个字符串进行搜索。如果需要根据查询匹配对结果进行排序,可以使用以下方法: 1. 使用 CONCAT 和 LIKE 函数 可以使用 CONCAT 函数将多个字段合并成一个字符串,然后使用 LIKE 运算符进行模糊搜索,例如: SELECT * FROM table WHERE CONCAT(column1, column2, column3) LIKE '%keyword%' ORDER BY (column1 LIKE '%keyword%') + (column2 LIKE '%keyword%') + (column3 LIKE '%keyword%') DESC; 这个语句中,将 column1、column2 和 column3 合并成一个字符串进行模糊搜索。然后使用 LIKE 运算符判断每个字段是否匹配关键词,匹配则返回 1,否则返回 0。最后将三个字段匹配结果相加,作为整个匹配值,按照匹配值进行降序排序。 2. 使用 MATCH AGAINST 函数 MySQL 中提供了 MATCH AGAINST 函数用于全文搜索,可以对多个字段进行全文搜索,并且可以根据匹配进行排序,例如: SELECT *, MATCH(column1, column2, column3) AGAINST ('keyword') AS relevance FROM table WHERE MATCH(column1, column2, column3) AGAINST ('keyword') ORDER BY relevance DESC; 这个语句中,使用 MATCH AGAINST 函数对 column1、column2 和 column3 进行全文搜索,并且将匹配值作为一个别名为 relevance 的字段返回。然后根据 relevance 字段进行降序排序。 以上是两种常见的 MySQL 模糊搜索并根据查询匹配排序的方法,可以根据实际需求选择使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值