如何解决可以在一个选择中多次使用动态列吗?
我进行了一些复杂的字符串替换,并且只允许我进行只读访问。
我想有几列,每列都依赖于上一列,以便查看我的substring
和charindex
函数是否正确。
基本上是这样:
DECLARE @myvar NVARCHAR(100) = 'ThisIsMyTest'
SELECT REPLACE(@myvar,'My','Our') AS Part1,Part1 + ' added to the end'
我希望第二列的输出为:
ThisIsOurTest added to the end
这是我要完成的工作的极其简化的版本,因此我正在寻找概念。我不需要这个答案:
SELECT REPLACE(@myvar,'Our') as Part1,REPLACE(@myvar,'Our') + ' added to the end'
这就是我现在正在做的事情。
解决方法
在SQL Server中,一个选项使用横向联接。在这种情况下,它们很方便,因为“下一个”联接可以访问由先前联接生成的数据集。基本上,您可以将每个中间计算放在单独的(标量)子查询中。
从您的简化示例开始,将是:
select t1.part1,t2.part2
from (values (replace(@myvar,'My','Our'))) t1(part1)
cross apply (values (t1.part1 + ' added to the end')) t2(part2)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。