动态透视:巧妙地将行转换为列
动态SQL语句是创建灵活查询的强大工具。本文将重点介绍如何在不使用聚合函数的情况下,将行转换为列。
理解动态透视
透视操作通常使用SUM或MAX等聚合函数。然而,在某些情况下,直接获取值透视是可取的。这需要一种略微不同的方法。
例如,考虑以下源表:
<code>╔═══════════╦══════╦═══════╗ ║ TEST_NAME ║ SBNO ║ VAL ║ ╠═══════════╬══════╬═══════╣ ║ Test1 ║ 1 ║ 0.304 ║ ║ Test1 ║ 2 ║ 0.31 ║ ║ Test1 ║ 3 ║ 0.306 ║ ║ Test2 ║ 1 ║ 2.3 ║ ║ Test2 ║ 2 ║ 2.5 ║ ║ Test2 ║ 3 ║ 2.4 ║ ║ Test3 ║ 1 ║ PASS ║ ║ Test3 ║ 2 ║ PASS ║ ╚═══════════╩══════╩═══════╝</code>
期望的输出是一个类似于以下的透视表:
<code>╔══════════════════════════╗ ║ SBNO Test1 Test2 Test3 ║ ╠══════════════════════════╣ ║ 1 0.304 2.3 PASS ║ ║ 2 0.31 2.5 PASS ║ ║ 3 0.306 2.4 NULL ║ ╚══════════════════════════╝</code>
无需聚合函数的动态透视
为了在不使用聚合函数的情况下实现此结果,我们可以利用PIVOT函数。由于VAL列包含varchar数据,我们可以利用MAX聚合函数。
硬编码透视
对于数量有限的测试,我们可以按如下方式硬编码列名:
<code class="language-sql">select sbno, Test1, Test2, Test3 from ( select test_name, sbno, val from yourtable ) d pivot ( max(val) for test_name in (Test1, Test2, Test3) ) piv;</code>
可扩展的动态透视
对于大量的测试,动态SQL提供了一种可扩展的解决方案:
<code class="language-sql">DECLARE @cols AS NVARCHAR(MAX), @query AS NVARCHAR(MAX) select @cols = STUFF((SELECT distinct ',' + QUOTENAME(TEST_NAME) from yourtable FOR XML PATH(''), TYPE ).value('.', 'NVARCHAR(MAX)') ,1,1,'') set @query = 'SELECT sbno,' + @cols + ' from ( select test_name, sbno, val from yourtable ) x pivot ( max(val) for test_name in (' + @cols + ') ) p ' execute(@query)</code>
两种方法都会产生相同的期望输出。此示例演示了如何利用动态SQL来创建灵活且高效的解决方案,以解决复杂的数据处理任务。
以上是如何在不聚合的情况下在 SQL 中执行动态透视?的详细内容。更多信息请关注PHP中文网其他相关文章!