【问题标题】:Create Comma Delimiter in Select Query在选择查询中创建逗号分隔符
【发布时间】:2014-01-27 02:40:54
【问题描述】:

我这里有一个查询,它给出了两行结果:

SELECT @SlsChannelDiv= a.division,@SlsChannel= a.department
                    FROM dbo.m_SalesCode a left join dbo.m_SalesCode b 
                    ON a.up1_code=b.sales_code left join vwEmployeeAds v 
                    ON a.user_id=v.login
                    WHERE v.login = @SalesLogin

我想将@SlsChannel 参数用于其他查询。

Select * from wo where sales in (@SlsChannel)

但这总是给出第一行结果。

我可以通过提供 XML 路径来修改我的第一个查询:

SELECT @SlsChannelDiv= a.division,@SlsChannel= a.department
                        FROM dbo.m_SalesCode a left join dbo.m_SalesCode b 
                        ON a.up1_code=b.sales_code left join vwEmployeeAds v 
                        ON a.user_id=v.login
                        WHERE v.login = @SalesLogin For XML PATH ('')

但是,我收到错误消息,例如:The FOR XML clause is not allowed in a ASSIGNMENT statement.

是否可以在In 参数中创建@SLSChannel 值,以逗号分隔?

【问题讨论】:

  • 您想用相应的@SlsChannelDiv 项目替换任何为NULL 的单个@SlsChannel item 还是替换整个@SlsChannel list@SlsChannel 列表为NULL 时与其他列表一起使用?
  • 不,请阅读我想做的事情,在这种情况下,我要使用的查询是 Select * from wo where sales in (@SlsChannel) 为什么我有 @SlsChannelDiv= a.division,@SlsChannel= a.department 我有多个条件
  • 是的,这似乎或多或少很清楚,我只是试图将它与您稍后添加的注释相协调,您所说的sometimes @SlsChannel has no value so I'll use @SlsChannelDiv。但是你现在已经删除了它,我想@bluejaded 的建议应该就可以了。
  • 是的,很抱歉混淆了注释,我的意思是实际上我将查询用于多个条件。却误写成这样。

标签: sql sql-server delimiter for-xml-path


【解决方案1】:
Select * from wo where sales in (SELECT a.department
                FROM dbo.m_SalesCode a left join dbo.m_SalesCode b 
                ON a.up1_code=b.sales_code left join vwEmployeeAds v 
                ON a.user_id=v.login
                WHERE v.login = @SalesLogin)

这样查询怎么样? :)

【讨论】:

  • 哦,是的,当然有可能,但我应该修改我的大部分代码,但我担心我的查询有多个条件,有时@SlsChannel 没有价值,所以我会使用@ 987654323@
  • 如果我错了,请纠正我,但您希望您的第一个查询返回多行,对吗?我猜你不应该给它分配任何变量,因为它真的会返回一行。您可以只使用临时表,插入第一个查询的查询结果。然后,执行此“Select * from wo where sales in (Select column from #temptable)。不需要逗号分隔值。
  • 啊,你明白了,是的,如果我分配给任何变量,它只会给出一个值。好的,我将对我的代码进行一些修改
猜你喜欢
  • 1970-01-01
  • 2013-08-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-28
  • 2011-06-20
  • 1970-01-01
相关资源
最近更新 更多