首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何将多个值传递给参数?

如何将多个值传递给参数?
EN

Stack Overflow用户
提问于 2019-05-22 23:37:31
回答 2查看 49关注 0票数 1

我试图在select语句中传递一个或多个输入变量

我尝试使用IN语句

代码语言:javascript
运行
复制
DECLARE @LOANKIND VARCHAR(100)
SET @LOANKIND = 'Payables - Loan,Payables - Lines of Credit'
SELECT * from Table
WHERE LOANKIND.KIND_DESC IN (@LOANKIND)

我所有可能的值是:

应付款-贷款,应付款-信用额度,应付款-可收回奖助金,应付款-奖励金,应付款-债券,应付款-担保,应收款-贷款,应收款-信用额度,应收款-可收回奖助金,应收款-担保

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-05-22 23:43:41

为此,您可以使用动态查询。如下所示:

代码语言:javascript
运行
复制
DECLARE @sql nvarchar(max)
DECLARE @LOANKIND VARCHAR(100)
SET @LOANKIND = '''Payables - Loan'', ''Payables - Lines of Credit'''
SET @sql = 'SELECT * from Table WHERE LOANKIND.KIND_DESC IN (' + @LOANKIND + ')'

SP_EXECEUTESQL @sql
票数 1
EN

Stack Overflow用户

发布于 2019-05-23 02:29:30

另一种方式。

如果你有SQL 2016+,你可以使用STRING_SPLIT。否则,您可以下载DelimitedSplit8K

代码语言:javascript
运行
复制
-- Sample Data
DECLARE @Table TABLE (KIND_DESC VARCHAR(100));
INSERT  @Table(KIND_DESC) VALUES ('Payables - Pizza'),('Payables - Loan'),('Payables - Lines of Credit');

-- Solution
DECLARE @LOANKIND VARCHAR(100) = 'Payables - Loan,Payables - Lines of Credit'

SELECT * 
FROM @Table AS LOANKIND
JOIN STRING_SPLIT(@LOANKIND,',') AS s
ON   LOANKIND.KIND_DESC = s.[value];
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56260453

复制
相关文章

相似问题

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