7

这就是我试图以最简单的形式实现的目标:

SELECT 
    p.ProductId,
    p.ProductName,
    p.SKU
FROM tbl_Product p
WHERE (p.ProductName LIKE '%white%' OR p.SKU LIKE '%white%')
AND (p.ProductName LIKE '%cup%' OR p.SKU LIKE '%cup%')

我正在尝试在 UDF 中执行此操作,它接受所有搜索词的逗号分隔参数。

我尝试将该参数拆分为一个临时表并尝试连接,如下所示:

DECLARE @SearchText nvarchar(1000) SELECT @SearchText='white,cup'

DECLARE @SearchTerms TABLE (String nvarchar(200))
INSERT INTO @SearchTerms (String)
SELECT '%' + String + '%' FROM dbo.CsvSplitString(@SearchText)

SELECT 
    p.ProductId,
    p.ProductName,
    p.SKU
FROM tbl_Product p
JOIN @SearchTerms s ON (p.ProductName LIKE s.String OR p.SKU LIKE s.String)

但这不会返回我想要的 - 它返回名称或 SKU 与任一搜索词匹配的任何记录。我需要它像第一个查询一样返回,其中名称或 SKU 匹配所有搜索词(我认为这是有道理的)。

将非常感谢朝着正确的方向推动 - 如果您需要我更具体,请告诉我。

注意:全文搜索目前不是一个可行的选择。

谢谢!

4

2 回答 2

4

下面的查询应该可以做到,但它可能不是最快的!

DECLARE @SearchText nvarchar(1000) SELECT @SearchText='white,cup'
DECLARE @keywords TABLE (keyword nvarchar(255))
DECLARE @keywordCount int

INSERT INTO @keywords (keyword) SELECT * FROM dbo.CsvSplitString(@SearchText)
SET @keywordCount = (SELECT COUNT(*) FROM @keywords)


SELECT *
FROM tbl_Product p
WHERE EXISTS
    (SELECT *
    FROM
        (SELECT productId
        FROM tbl_Product, @keywords
        WHERE productname like '%' + keyword + '%' or sku like '%' + keyword + '%' 
        GROUP BY productid
        HAVING COUNT(*) = @keywordCount
        ) matches 
    WHERE p.ProductId=matches.ProductId
    )
于 2012-04-24T15:02:44.007 回答
0

如果一切都失败了,您可以运行光标@SearchTerms并循环遍历结果,检查每个项目是否存在于您的结果中。

您很可能不会有很多搜索项(5-6 会非常罕见),因此与like在文本上一遍又一遍地运行相比,光标成本应该可以忽略不计。这也不应该太贵。

编辑:我过去所做的搜索是以纯文本形式将查询发送到服务器,而不是依赖存储过程,所以我可以自己拼凑我的条件。如果您愿意,您可以对动态查询和exec服务器执行相同的操作。这种方式看起来很老套,而且性能提升并不明显。深思熟虑。

于 2012-04-24T14:45:39.853 回答