SQL按type计算行数的三种方法
时 间:2008-03-31 18:35:46
作 者:Rudy Limeback, ID:92 城市:北京
摘 要:SQL按type计算行数的三种方法
正 文:
Type
A
B
A
C
A
B
所以在这个表中这个单独的字段里有六条记录。请帮助我写一个查询获得下面的结果:
A B C
3 2 1
换句话说我想获得单独的Type字段数据和它们的数量。
Rudy Limeback:
有三种方式可以实现它:
select ( select count(*)
from TestTable where Type = 'A' ) as A , ( select count(*) from TestTable where Type = 'B' ) as B , ( select count(*) from TestTable where Type = 'C' ) as C |
在有些数据库里这第一个查询确实可以运行,但是它不是标准的SQL,因为它缺少了FROM条件。添加上双重FROM(或者其他任何一行的表)。
select sum( case when Type = 'A'
then 1 else 0 end ) as A , sum( case when Type = 'B' then 1 else 0 end ) as B , sum( case when Type = 'C' then 1 else 0 end ) as C from TestTable |
第二个查询确实可以得出你想要的,但是就像第一个查询一样,如果你发觉需要增加另一个Type,维护起来很麻烦。
select Type
, count(*) from TestTable group by Type |
第三个查询是最好的。不只是它一看就很容易理解,而且当添加新的Types时它还不需要维护。此外,它认为这个表达式不应该在数据库层处理。
顺便,因为你的表只有一列,而它具有重复的值,这个列不能作为主键,因此这个表没有主键。有人会说它因此不是一个“真正”的表,是个包。
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 通过命令按钮让Access列表...(04.24)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)

学习心得
最新文章
- 仓库管理实战课程(15)-月度库存...(04.30)
- Access选择打印机、横纵向、纸...(04.29)
- 仓库管理实战课程(14)-出库功能...(04.26)
- 通过命令按钮让Access列表框指...(04.24)
- 仓库管理实战课程(13)-入库功能...(04.21)
- Access控件美化之--美化按钮...(04.19)
- Access多行文本按指定字符筛选...(04.18)
- Microsoft Access数...(04.18)
- 仓库管理实战课程(12)-月度结存...(04.16)
- 仓库管理实战课程(11)-人性化操...(04.15)