文档章节

MySQL 关键字模糊匹配,并按照匹配度排序

yh32
 yh32
发布于 10/21 15:49
字数 347
阅读 35
收藏 10

MySQL 关键字模糊匹配,并按照匹配度排序。

方式一、按照关键字搜索,然后根据关键字所占比例排序

SELECT
	drug_name,
	pinyin
FROM
	tbl_drug
WHERE
	pinyin LIKE '%AM%'
ORDER BY
	LENGTH(pinyin);

效果如下

方式二、将关键字开头记录排序在前

SELECT
	drug_name,
	pinyin
FROM
	tbl_drug
WHERE
	pinyin LIKE 'AM%'
UNION
	SELECT
		drug_name,
		pinyin
	FROM
		tbl_drug
	WHERE
		pinyin LIKE '%AM%';

效果如下

方式三、将关键字开头排序在前,再根据匹配度排序记录

SELECT
	drug_name,
	pinyin
FROM
	(SELECT
		drug_name,
		pinyin
	FROM
		tbl_drug
	WHERE
		pinyin LIKE 'AM%'
	ORDER BY
		LENGTH(pinyin)
	LIMIT 999999) t1
UNION
	SELECT
		drug_name,
		pinyin
	FROM
		(SELECT
			drug_name,
			pinyin
		FROM
			tbl_drug
		WHERE
			pinyin LIKE '%AM%'
		ORDER BY
			LENGTH(pinyin)
		LIMIT 999999) t2
LIMIT 0,20;

结果如下,这块中文“()”所占长度较大,在此有一个问题,子查询的排序无效,如果子查询中order by 不带limit,会被优化器干掉

以上方式为网上整理总结,下面这个方式为个人改进

方式四、先根据关键字所在字段index排序,然后再根据匹配度排序

SELECT
    drug_name,
    pinyin
FROM
    tbl_drug
WHERE
    pinyin LIKE '%AM%'
ORDER BY
    LENGTH(substring_index(pinyin,'AM',1)),
    LENGTH(pinyin)
LIMIT 0,20

效果如下

© 著作权归作者所有

共有 人打赏支持
yh32
粉丝 2
博文 34
码字总数 9943
作品 0
广州
后端工程师
私信 提问
MySQL对Like搜索结果按照匹配程度排序

MySQL对Like搜索结果按照匹配程度排序 钇钛网 - 郭宇翔的博客2018-01-091 阅读 匹配mysql排序like搜索 最近项目上遇到一个需求,在原来项目的管理后台上,有一个通过用户昵称进行模糊搜索的功...

钇钛网 - 郭宇翔的博客
01/09
0
0
如何解决mysql本地登陆不能登录的问题

在MySQL数据库中,使用select user();查看当前登陆用户。mysql中host字段的%与localhost不是谁包括谁的问题,是由精确到模糊进行匹配的。 说明 当用户从客户端请求登陆时,MySQL将授权表中的...

问题终结者
06/26
0
0
23 款实用的 Elasticsearch 查询示例

ElasticSearch是一个基于Lucene的搜索服务器,它是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。本文介绍了几种常用的Elasticsearch查询方式,并分别进...

达尔文
2016/11/16
7.1K
17
Python学习笔记十九(MySQL、SQL、查找、单表查询)

查找 查找分为单表查询与多表查询 单表查询 查看现有数据表 查看所有数据 查看某些字段 比如我只关心title 字段 或者 我只关心title 字段 和content_num 字段 给字段起别名 如果将查出来的结...

DragonFangQy
05/13
0
0
六、MySQL查询数据

6.1、基本查询语句 MySQL从数据表中查询数据的基本语句为SELECT语句,其基本格式为: SELECT {* | } [ FROM ,... [WHERE 表达式 [GROUP BY ] [HAVING [{ }...]] [ORDER BY...

运维菜鸟丶
2017/08/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

数据解析之XPath & lxml库

XPath 定义 即XML路径语言(XML Path Language),是一种用来确定XML文档中某部分位置的语言,它基于XML的树状结构,提供在数据结构树中寻找节点的能力,也适用于HTML文档中; 开发工具 Chrome...

村雨1943
27分钟前
2
0
day148-2018-11-15-英语流利阅读-待学习

赴美生子恐结束?特朗普中期选举憋大招 毛西 2018-11-15 1.今日导读 在 2013 年,一部《北京遇上西雅图》让赴美生子这个曾经神秘的话题吸引了很多关注。每年,数以万计的父母远赴美国,并在那...

飞鱼说编程
57分钟前
34
0
OSChina 周四乱弹 —— 每次我穿短裙的时候

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @瘟神灬念 :分享DM DOKURO的单曲《Reality Check Through The Skull》: 差点以为手机卡了 《Reality Check Through The Skull》- DM DOKURO...

小小编辑
今天
537
10
Windows 10 设置 Java 环境变量

首先你需要在我的电脑中打开,找到环境变量属性。 找到环境变量属性 找到环境变量属性后单击将会看到下面的设置界面。 在这个界面中设置高级系统设置。 环境变量 在弹出的界面中选择设置环境...

honeymose
今天
4
0
用any-loader封装jQuery的XHR —— 随便写着玩系列

哎,都说没人用JQuery啦,叫你别写这个。 其实我也是好高骛远使用过npm上某个和某个很出名的XHR库,嗯,认识我的人都知道我喜欢喷JQ,以前天天喷,见面第一句,你还用JQ,赶紧丢了吧。但我也...

曾建凯
今天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部