代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
MSSQL
】
按年月统计并行列转换
作者:
Dezai.CN
/ 发布于
2012/3/9
/
716
<div> 1 创建表 CREATE TABLE [dbo].[Orders]( [ID] [int] IDENTITY(1,1) NOT NULL, [Amount] [int] NULL, [Year] [int] NULL, [Month] [smallint] NULL, CONSTRAINT [PK_Orders] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] 2 初始化数据 insert into [Orders] select 100,2010,1 union all select 200,2010,2 union all select 200,2010,2 union all select 200,2010,2 union all select 180,2010,5 union all select 100,2010,7 union all select 150,2010,8 union all select 150,2010,8 union all select 150,2010,8 union all select 108,2010,10 union all select 100,2010,11 union all select 108,2010,12 union all select 200,2009,2 union all select 180,2009,5 union all select 100,2009,7 union all select 150,2009,8 union all select 150,2009,8 union all select 150,2009,8 union all select 108,2009,10 union all select 100,2009,11 union all select 108,2009,12 select * from [Orders] --------sql 2005------ SELECT * FROM ( SELECT year,month,amount FROM [Orders]) p PIVOT (SUM (amount) FOR month IN ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]) ) AS amount -------sql 2000----- select year, [1] = Sum ( case when month ='1' then amount else 0 end ), [2] = Sum ( case when month ='2' then amount else 0 end ), [3] = Sum ( case when month ='3' then amount else 0 end ), [4] = Sum ( case when month ='4' then amount else 0 end ), [5] = Sum ( case when month ='5' then amount else 0 end ), [6] = Sum ( case when month ='6' then amount else 0 end ), [7] = Sum ( case when month ='7' then amount else 0 end ), [8] = Sum ( case when month ='8' then amount else 0 end ), [9] = Sum ( case when month ='9' then amount else 0 end ), [10] = Sum ( case when month ='10' then amount else 0 end ), [10] = Sum ( case when month ='10' then amount else 0 end ), [12] = Sum ( case when month ='12' then amount else 0 end ), [count] = Sum ( case when month <> '' then amount else 0 end ) from [Orders] GROUP BY year </div>
试试其它关键字
按年月统计并行列转换
同语言下
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3