首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >动态SQL搜索改进

动态SQL搜索改进
EN

Stack Overflow用户
提问于 2021-02-03 20:15:55
回答 1查看 43关注 0票数 0

我使用下面的SQL查询在数据库中进行动态搜索:

代码语言:javascript
运行
复制
SELECT [Name],[Vendor]
FROM OrderedApps
Where Name like '%' + 'Microsoft Visio' + '%' OR [Vendor] like '%' + 'Microsoft Visio' + '%'

在数据库中,我有:

代码语言:javascript
运行
复制
Name         Vendor
Visio Viewer Microsoft
Office Visio Microsoft
Office test  Microsoft

如果我提供输入Microsoft Visio

我想把它列出来

代码语言:javascript
运行
复制
Name         Vendor
Visio Viewer Microsoft
Office Visio Microsoft

我如何改进我的SQL查询来实现这一点?我已经搜索过了,但还没有找到我想要做的事情。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-03 20:42:04

要么将参数作为表值参数传递,要么作为单词列表传递。

或者在SQL中将其拆分:

代码语言:javascript
运行
复制
DECLARE @words TABLE (word varchar(100) PRIMARY KEY);
INSERT @words (word)
SELECT value
FROM STRING_SPLIT(@myparam, ' ');

然后,您可以取消旋转您的列以进行搜索,并像这样连接它:

代码语言:javascript
运行
复制
SELECT [Name],[Vendor]
FROM OrderedApps oa
WHERE EXISTS (
    SELECT 1
    FROM @words w
    LEFT JOIN (VALUES
        (oa.Name),
        (oa.Vendor)
    ) v (col)
        ON v.col LIKE '%' + w.word + '%'
    HAVING COUNT(CASE WHEN v.col IS NULL THEN 1 END) = 0  -- this line ensures that every word matches at least once
);

如果你只想要单词列表中的任何匹配,这要容易得多:

代码语言:javascript
运行
复制
WHERE EXISTS (
    SELECT 1
    FROM @words w
    JOIN (VALUES
        (oa.Name),
        (oa.Vendor)
    ) v (col)
        ON v.col LIKE '%' + w.word + '%'
);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66027377

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档