此 SQL 代码动态地将行转换为列,而不会丢失数据类型,这通常需要聚合函数。让我们重新表述一下,以使其更加清晰并提高可读性。
在 SQL 中动态地将行转换为列:类型保留解决方案
标准 SQL PIVOT
操作通常需要聚合函数(如 MAX
或 MIN
),这可能会导致数据丢失或类型强制。此示例演示了一种动态 SQL 方法,可将行转换为列,同时保留原始数据类型,最多处理 12 个测试名称。
挑战在于将具有可变数量的测试名称(最多 12 个)和混合数据类型的表转换为每个测试名称成为一列的表。 需要一个动态解决方案来适应这种变化。
动态 SQL 解决方案
这个解决方案巧妙地使用动态 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>
代码首先根据唯一的 @cols
值构建一个以逗号分隔的列名称列表 (TEST_NAME
)。 然后,它使用 PIVOT
作为聚合函数来构造 @query
查询 (MAX(val)
)。 当使用 MAX
时,因为我们以每个 SBNO 内的唯一值为基础,这有效地保留了原始数据。 最后,执行生成的查询。
说明性输出
输出表将为每个唯一的测试名称有一列,并用原始表中的相应值填充,并保持其原始数据类型:
<code>| SBNO | TEST1 | TEST2 | TEST3 | --------------------------------- | 1 | 0.304 | 2.3 | PASS | | 2 | 0.31 | 2.5 | PASS | | 3 | 0.306 | 2.4 | (null) |</code>
此方法可以有效处理不同数量的测试名称和不同的数据类型,为 SQL 中的动态旋转提供强大的解决方案。 请记住将 yourtable
替换为您的表的实际名称。
以上是如何在 SQL 中动态地将行转换为列而不进行聚合?的详细内容。更多信息请关注PHP中文网其他相关文章!