如何执行枢纽功能
我有一张有数据的表
Day Period subject fromtime totime
----------------------------------------------
Monday 1st English 9:30 10:15
Monday 1st English 9:30 10:15
Monday 5th English 1:30 2:20
Monday 8th English 3:40 4:30
但我需要的格式为
day period(1st) 2nd 3rd...... 5th... 8th
--------------------------------------------------------------------------
Monday 1st nill nill 5th 8th
english english english
Tuesday .......
这样。
如何执行数据透视功能以这种格式获取。
请帮帮我........
我用过我的查询
SELECT DAY, [1st],[2nd],[3rd],[4th], [5th],[6th],[7th], [8th]
FROM
(
SELECT Day, Period, Subject,FromTime,ToTime
FROM StaffTimeTableEntry
) up
PIVOT (Min(Subject) FOR Period IN ([1st],[2nd],[3rd],[4th], [5th],[6th],[7th], [8th])) AS pvt
order by Day
结果显示为
day 1st 2nd 3rd 4th 5th 6th 7th 8th
----------------------------------------------------------------------------------
Friday NULL NULL NULL NULL NULL NULL English NULL
Monday NULL NULL NULL NULL English NULL NULL NULL
Monday NULL NULL NULL NULL NULL NULL NULL English
Monday English NULL NULL NULL NULL NULL NULL NULL
Saturday NULL NULL NULL NULL NULL English NULL
Thursday NULL NULL NULL English NULL NULL NULL
Tuesday NULL English NULL NULL NULL NULL NULL NULL
Tuesday NULL NULL NULL NULL NULL English NULL NULL
Wednesday NULL NULL NULL NULL NULL English NULL
但在这里我也有3个星期一的记录,而不是一个星期一的记录…
如何获得每天1天的一个记录…?
试试这个:
SELECT DAY, [1st],[2nd],[3rd],[4th], [5th],[6th],[7th], [8th]
FROM
(
SELECT Day, Period, Subject --,FromTime,ToTime
FROM StaffTimeTableEntry
) up
PIVOT (Min(Subject) FOR Period IN ([1st],[2nd],[3rd],[4th], [5th],[6th],[7th], [8th])) AS pvt
order by Day
PIVOT运算符未“消耗”的任何列将保留在最终结果集中,从而增加了基数。
问题内容: 示例选择: 输出: 是否可以按时间顺序对记录进行排序,排除列“月”和“年”?没有列出所有列。 UPD 需要: 就像是: 问题答案: 要对记录进行排序,可以将以下内容添加到sql的末尾 注意:枢轴列名称区分大小写,因此需要用引号引起来 这是完整的查询,仅选择您需要的列:
问题内容: 我有一张这样的产品零件表: 部分 我想要一个查询,将返回这样的表: 在其实际实施中,将有数百万个产品零件 问题答案: 不幸的是,MySQL没有函数,但是您可以使用聚合函数和语句对其进行建模。对于动态版本,您将需要使用准备好的语句: 请参见带有演示的SQL Fiddle 如果只有几列,则可以使用静态版本:
我在使用PIVOT SQL脚本时遇到了一个“小”问题。我目前的解决方案基于类似的问题 动态枢轴 . 我已经写好了PIVOT脚本,基本上没问题。然而,我的情况是这样的,脚本输出类似这样的内容,而不是将唯一的条目放在单行上 而我所寻找的结果应该是这样的 这是脚本 我将不胜感激一些可以帮助我解决这个问题的指示。我在这里做了一个小提琴,由于某种奇怪的原因,它没有输出任何东西,但生成架构的所有代码都在那里
问题内容: 我有一个简单的查询,像这样。 一个简单的枢轴给了我 给我 但是数据透视查询中的值是硬编码。我想从子查询中获取这些值。 但是,pivot不允许我从子查询中获取值,除了编写动态生成的查询之外,还有其他方法可以执行此操作吗? 问题答案: 不能。只能使用动态查询来完成。我真的很想知道是否有办法。
我想执行每个产品的平均评级,存储在数据透视表中称为“评论”。下面是我现有的代码。 产品型号: 用户模型: 审查的迁移 我试图使用下面的代码构造预期的输出,但它导致了N+1个问题,因为它没有利用Laravel口才的急切加载。 预期产出: