sql - SQL - 使用 LIKE 进行多个值的部分匹配

标签 sql sql-server tsql

我想寻求您的建议,SQL Server 中是否有任何函数允许我对值列表执行部分匹配?

需要匹配的整个字符串将通过存储过程传入​​。

在编写自己的函数之前,我试图找到其他替代方案,用逗号分割字符串,然后在将数据返回到程序之前合并所有结果。

例如,我会将以下字符串传递到我的 TSQL 中

apple,orange,pear

在我的 WHERE 子句中它应该匹配

select * from store where fruits like 'apple%'
select * from store where fruits like 'orange%'
select * from store where fruits like 'pear%'

我可以通过单个 SQL 语句实现上述结果,而不是编写函数来分解每个字符串吗?

Data in my Table

apple red
apple green
orange sweet
orange sour
pear big
pear small

所以,当我传入字符串“apple,pear”时,我需要返回

apple red
apple green
pear big
pear small

最佳答案

您可以创建一个临时表

'CREATE TABLE #Pattern (
      SearchItems VARCHAR(20)
    );'

旁注:请确保检查临时表是否存在以避免错误。 现在您可以将搜索词插入到临时表中,如下所示

'INSERT 
    INTO #Pattern 
    VALUES 
        ('% APPLE %'),
        ('% ORANGE %'),
        ('% BANANA %');'

现在使用此临时表,使用 INNER JOIN 搜索您的表 就像

'SELECT *
 FROM Store
 INNER JOIN #Pattern
    ON Store.Fruits LIKE SearchItems
'

需要注意的是,临时表是我最想避免的,但它在这里很方便,而且我使用此解决方案的情况对性能要求不高。相反,它使维护不断增长的搜索项变得更容易。

希望这也适用于其他人。

关于sql - SQL - 使用 LIKE 进行多个值的部分匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26621251/

相关文章:

.net - 是否有包含 RowVersion 值的 Microsoft.SqlServer.Management.Smo.SqlDataType 的替代方法?

sql - 如何在查询中添加和划分别名列?

sql - 获取两个日期之间的工作日数(周日、周一、周二)SQL

mysql - 我可以在没有外部包的情况下使用 Node.JS 连接到 SQL,还是使用一个通用包?

sql - Postgres 递归查询 - 获取给定叶节点的根路径

sql - 尝试通过脚本为 SQL Server 设置全文搜索

sql - 从文本中获取日期时间

sql - 使用 RANK() OVER 计数时跳过空值

sql - 从自定义电子邮件表发送电子邮件的代理作业

mysql - 如何编写使用同一个表中列的 MIN() 值的 WHERE 子句?