sql server pivot】的更多相关文章

在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表: WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL) 我们先插入一些模拟数据: INSERT INTO WEEK_INCOME UNION ALL UNION ALL UNION ALL UNION ALL UNION ALL UNION ALL 一般我们最经常使用的查询是查询一周中每天或某几天的收入,例如查询周一至周日全部的收入: SELECT WEEK,INC…
前段时间开发系统时,有个功能是动态加载列,于是就使用了SQL Server自带的PIVOT函数进行行转列,开始用的非常溜,效果非常好.但是提交测试后问题来了,测试添加的列名中包含空格,然后就杯具了,功能报错了, 一波未平一波又起,测试添加的数据中包含有以数字开头的,结果又GG了,好沮丧啊!!!!!! 于是开启了查找资料之路,发现只要把列名用方括号[]包起来,问题就解决了,然后就实践了一下,果然以上两个问题都解决了,世界瞬间美好了!!! 然后自己又添加了一些包含特殊字符等的数据,一切都OK没有出现…
通俗简单的说:PIVOT就是行转列,UNPIVOT就是列传行 在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表: WEEK_INCOME(WEEK ),INCOME DECIMAL) 我们先插入一些模拟数据: INSERT INTO WEEK_INCOME 一般我们最经常使用的查询是查询一周中每天或某几天的收入,例如查询周一至周日全部的收入: SELECT WEEK,INCOME FROM WEEK_INCOME 得到如下的查询结果集: WEEK  …
一般我们在使用SQL语句实现行列转置时候,最常用的方法无外乎就是 case语句来实现,但是如果需要需要转置的列太多,那么case起来语句就无限庞大,十分不方便,sql server中的PIVOT就可以帮助我们解决此类问题 PIVOT語法,如下: SELECT <non-pivoted column>,     [first pivoted column] AS <column name>,     [second pivoted column] AS <column name…
参照这个网址介绍 http://www.cnblogs.com/lwhkdash/archive/2012/06/26/2562979.html 一般SQL Server的函数都会识别为紫色,可是PIVOT却是灰色,我一开始以为是SQL Server不能使用,但能正常使用 可以使用print @@version确认下兼容级别,90的是没问题的 Microsoft SQL Server 2005 - 9.00.4060.00 (X64) 数据库右键->属性->选项 这聚合函数对text,nvar…
有时候会碰到行转列的需求(也就是将列的值作为列名称),通常我都是用 CASE END + 聚合函数来实现的. 如下: declare @t table (StudentName nvarchar(20), Subject nvarchar(20), Score int) Insert into @t (StudentName,Subject,Score) values ( '学生A', '中文', 80 ); Insert into @t (StudentName,Subject,Score)…
[pivot]行转列:多行变一列 假设学生成绩表Score1 Name Subject Score 小张 语文 88 小花 数学 89 小张 数学 90 Name 语文 数学 小花 null 89 小张 88 90 --一定要有聚合函数, 如sum(Score) select * from Score1 pivot (sum(Score) for Subject in (语文,数学)) b [unpivot]列转行:一列变多行 假设学生成绩表Score2 Name Chinese Math 小花…
--现在我们是用PIVOT函数将列[WEEK]的行值转换为列,并使用聚合函数Count(TotalPrice)来统计每一个Week列在转换前有多少行数据,语句如下所示 select * from ShoppingCart as C PIVOT(count(TotalPrice) FOR [Week] IN([1],[2],[3],[4],[5],[6],[7])) AS T…
SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[YearSalary]( [year] [int] NULL, [salary] [money] NULL ) ON [PRIMARY] GO select * from yearsalary; ],[],[],[],[],[],[],[],[] from ( select year,salary from yearsalary) as SourceTable…
##目录 #####清除缓存 DBCC FREEPROCCACHE; DBCC DROPCLEANBUFFERS; SELECT stock.IdStock, stock.Descr FROM [Inventory].[dbo].[Stock] stock WHERE stock.IdStock NOT IN (SELECT foreignStockId FROM [Subset].[dbo].[Products]) #####如何获取当月统计总数 * Column.Table.datetime…