首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Server -创建pivot的简单方法

SQL Server -创建pivot的简单方法
EN

Stack Overflow用户
提问于 2013-08-21 18:44:44
回答 1查看 116关注 0票数 0

有没有人知道一个简单的方法来创建这个结果的轴心:

代码语言:javascript
复制
[0-1]  [1-2]  [2-3]  [3-4]
12      45      29    5

此结果是通过查询创建的:

代码语言:javascript
复制
 SELECT [0-1]   = SUM(CASE WHEN AGE >= 0 AND AGE <= 1 THEN 1 ELSE 0 END),
       [1-2]  = SUM(CASE WHEN AGE > 1 AND AGE <= 2 THEN 1 ELSE 0 END),
       [2-3] = SUM(CASE WHEN AGE > 2 AND AGE <= 3 THEN 1 ELSE 0 END)
    FROM dbo.Persons

我希望将列值显示为行,即输出应如下所示:

代码语言:javascript
复制
[0-1]      12
[1-2]      45
[2-3]      29
[3-4]       5

文章/博客的链接也很受欢迎。请建议一个简单易用的解决方案。

EN

回答 1

Stack Overflow用户

发布于 2013-08-21 18:49:31

下面是一种使用cross join和聚合的方法:

代码语言:javascript
复制
select ages.minage, ages.maxage,
       sum(case when age > ages.minage and age <= ages.maxage then 1 else 0 end) as cnt
from dbo.Persons cross join
     (select -1 as minage, 1 as maxage union all
      select 1, 2 union all
      select 2, 3
     ) as ages
group by ages.minage, ages.maxage

我喜欢这种方法,因为它很容易添加新的年龄范围。请注意,这也包括范围。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18355311

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档