==================================声明==================================
本文原创,转载在正文中显要的注明作者和出处,并保证文章的完整性。
未经作者同意请勿修改(包括本声明),保留法律追究的权利。
未经作者同意请勿用于学术性引用。
未经作者同意请勿用于商业出版、商业印刷、商业引用。
本文不定期修正完善,为保证内容正确,建议移步原文处阅读。
本文链接:http://www.cnblogs.com/wlsandwho/p/4423956.html
=======================================================================
看了好长时间的资料,总算是看懂了点。(另外怎样才能把右面的这个长毛的土豆去掉?----> 对,就是它!)
赶紧记录下来。
=======================================================================
表格和数据。(和http://www.cnblogs.com/wlsandwho/p/4416222.html的相同)
1 USE tempdb 2 GO 3 -------------------------------------------------------------------------- 4 IF OBJECT_ID('Student','U') IS NOT NULL 5 DROP TABLE Student 6 GO 7 8 CREATE TABLE Student 9 (10 StuID NVARCHAR(8) PRIMARY KEY,11 Name NVARCHAR(5),12 EntranceTime DATETIME13 )14 GO15 16 INSERT INTO Student(StuID,Name,EntranceTime) VALUES('20080001','Lily','2008-08-27')17 INSERT INTO Student(StuID,Name,EntranceTime) VALUES('20090002','Lucy','2009-08-26')18 INSERT INTO Student(StuID,Name,EntranceTime) VALUES('20070003','Jack','2007-08-28')19 GO20 --------------------------------------------------------------------------21 IF OBJECT_ID('SltCourse','U') IS NOT NULL22 DROP TABLE SltCourse23 GO24 25 CREATE TABLE SltCourse --SelectiveCourse26 (27 ID INT PRIMARY KEY IDENTITY(1,1),28 StuID NVARCHAR(8),29 CourseName NVARCHAR(10),30 Score INT 31 )32 GO33 34 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20070003','电脑维修',90)35 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20070003','剪纸',80)36 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20070003','市场策划',95)37 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20070003','信息检索',100)38 39 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20080001','插花',99)40 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20080001','剪纸',96)41 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20080001','刺绣',92)42 43 INSERT INTO SltCourse(StuID,CourseName,Score) VALUES('20090002','插花',98)44 GO
查看一下
1 SELECT s.StuID,s.Name,s.EntranceTime,sc.CourseName,sc.Score FROM Student s,SltCourse sc WHERE s.stuid=sc.stuid2 GO
=======================================================================
现在来看这个表格,前三列有很多数据是重复的,而且也不便于阅读。之前使用了row_number函数,这里使用下别的——PIVOT来实现一个行转列。
预期效果。
=======================================================================
静态版。这需要预知要转换成列名的数据。
1 WITH ReportCard 2 AS(3 SELECT s.StuID,s.Name,s.EntranceTime,sc.CourseName,sc.Score FROM Student s,SltCourse sc WHERE s.stuid=sc.stuid4 )5 SELECT * FROM ReportCard PIVOT(MAX(Score) FOR CourseName IN([电脑维修],[剪纸],[市场策划],[信息检索],[插花],[刺绣]) ) AS T6 GO
结果。
新闻热点
疑难解答