sql - 当我不想使用聚合时,是否应该使用 Pivot 将 SQL Server 2008 行值转换为列名?

标签 sql sql-server sql-server-2008 tsql pivot-without-aggregate

我正在尝试将表数据操作为更具视觉吸引力的输出格式。这可能是问题的一部分,因为我想要的可能是用于单独的报告软件。

我有一个看起来像这样的表格

teacher    student
----------------------
teacher1   Bob
teacher1   Jim
teacher2   Sam
teacher3   Bill
teacher3   John
teacher3   Eric

我想要一个看起来像这样的表格:

teacher1    teacher2    teacher3
---------------------------------
Bob         Sam          Bill
Jim         null         John
null        null         Eric

所以我尝试将所有教师姓名填充到一个变量中,然后使用Pivot,但由于我必须选择一个聚合,所以我只能获得Max >最小学生喜欢这样:

DECLARE @teacherList AS VARCHAR(max)

SELECT @teacherList = Stuff((SELECT DISTINCT',[' + teacher + ']'
                              FROM myTable
                              FOR xml path('')), 1, 1, '')

DECLARE @dynamic_pivot_query AS VARCHAR(max)

SET @dynamic_pivot_query = 'select' + @teacherList + 
'from 
(
    SELECT [teacher],[student]
    FROM [dbo].[myTable]
) as S
Pivot
(
    MIN([student])
    FOR teacher IN (' + @teacherList + ')
) as P
'
EXEC(@dynamic_pivot_query)  

结果是:

teacher1    teacher2    teacher3
---------------------------------
Bob         Sam          Bill

假设如下:

  1. # 名教师及其姓名未知(可变)
  2. 每个老师的学生数量未知,并且每个老师可能都不同

有办法做到这一点吗?

最佳答案

没有。

SQL Server 需要静态类型。无法创建动态数量的列或动态列类型(sql_variant 除外)。

因此,您的动态 SQL 解决方案是唯一可能的选择。

不要让最小/最大混淆:每个聚合总是有 0 或 1 个项目。语法需要聚合以保证理论正确性,但如果 (教师,学生) 是唯一的,则聚合不会执行任何操作。它没有任何害处,也不会改变结果。

这种方法就是正确的。实际上,我现在正在处理相同类型的代码(这很有趣)。

关于sql - 当我不想使用聚合时,是否应该使用 Pivot 将 SQL Server 2008 行值转换为列名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10285584/

相关文章:

SQL LIKE 运算符在存储的 JSON 中查找单词

mysql - UPDATE 查询中列的表名前缀

mysql - 如何使用特定条件的最高值对列表进行排序?

sql - 使用强制转换将 varchar 转换为日期

sql - 运行总计 (COUNT) SQL Server

sql - 用户定义的表类型插入有时会导致转换错误

MySQL - 按多个类别运行总计

php - 单击选项卡时如何将 sql 的结果显示到列表中?

mysql - 如何编写员工表和部门表的 SQL 查询

vb.net - 为什么我可以通过odbc连接到sql server 2008,但不能通过vb.net代码连接到sql server 2008?