SQL Server 按关健字模糊查询,并按匹配度排序的SQL语句
2022-11-12 09:54:02
内容摘要
这篇文章主要为大家详细介绍了SQL Server 按关健字模糊查询,并按匹配度排序的SQL语句,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
代
文章正文
这篇文章主要为大家详细介绍了SQL Server 按关健字模糊查询,并按匹配度排序的SQL语句,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | <code>IF OBJECT_ID( 'TB' )IS NOT NULL DROP TABLE TB GO CREATE TABLE tb (ID INT IDENTITY(1,1),VALUE NVARCHAR(100)) INSERT tb SELECT N '中国' UNION ALL SELECT N '中国人' UNION ALL SELECT N '中国人民' UNION ALL SELECT N '日本' UNION ALL SELECT N '日本人' UNION ALL SELECT N '我的心中有人姑娘' UNION ALL SELECT N '人民网' UNION ALL SELECT N '中国是个伟大的国家' UNION ALL SELECT N '我们都是中国人,都是炎黄子孙,都是龙人传人' IF OBJECT_ID( 'fn_SplitStringToROWS' )IS NOT NULL DROP FUNCTION fn_SplitStringToROWS GO CREATE FUNCTION fn_SplitStringToROWS ( @str NVARCHAR(100) ) RETURNS @t TABLE(v NVARCHAR(2)) AS BEGIN DECLARE @i INT SET @i=1 WHILE @i<=LEN(@str) BEGIN INSERT @t SELECT SUBSTRING(@str,@i,1) SET @i=@i+1 END RETURN END GO SELECT * FROM DBO.fn_SplitStringToROWS(N '中国人' ) DECLARE @searchSTR NVARCHAR(20) SET @searchSTR=N '中国人' SELECT ID,[VALUE] FROM tb a INNER JOIN fn_SplitStringToROWS(@searchSTR) b ON CHARINDEX(b.v,a.VALUE)>0 WHERE VALUE LIKE N '%[中国人]%' GROUP BY ID,VALUE ORDER BY COUNT (DISTINCT v) DESC DROP TABLE tb </code> |
注:关于SQL Server 按关健字模糊查询,并按匹配度排序的SQL语句的内容就先介绍到这里,更多相关文章的可以留意
代码注释