gpt4 book ai didi

SQL通配符不返回数据?

转载 作者:行者123 更新时间:2023-12-02 08:57:58 25 4
gpt4 key购买 nike

我有一个通过存储过程在 gridview 中使用的 select 语句:

SELECT * FROM T_Computer WHERE (ISTag LIKE '%' + @ISTag + '%') AND Status <> 'Trashed' AND Status <> 'Sold' AND Status <> 'Stored'

@ISTag,nchar 由文本框值确定,如果文本框为空,我将默认值设置为 %,在我看来,这应该本质上否定 where 子句的该部分并返回除被状态列否定的那些。相反,它没有返回任何内容。如果我删除“+ @ISTag +”,它就会执行我想要的操作。

基本上 3% 不会返回任何内容,但 2% 会返回我想要的内容。我该如何解决这个问题?

最佳答案

这里有一个替代方案,将@ISTag参数的默认值保留为NULL

SELECT * 
FROM T_Computer
WHERE (@ISTag IS NULL OR (ISTag LIKE '%' + @ISTag + '%'))
AND Status <> 'Trashed'
AND Status <> 'Sold'
AND Status <> 'Stored'

关于SQL通配符不返回数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3407585/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com