• 主页
  • 基础类
  • 应用实例
  • 新技术前沿

如何统计状态一样的数据并减去另外一个状态的数据

oceanaut 西安交通大学 项目总监  2006-10-17 09:26:07
在MS SQL Server中:如何统计状态一样的数据并减去另外一个状态的数据
pjtx_query字段:DKKBM,TXJE,PJZT

当PJZT=1时,将表中所有状态=1的数据加起来;并且减去其中状态=2的数据
(状态等于2的数据只有一条)
请写出具体的sql语句,谢谢!
...全文
148 点赞 收藏 15
写回复
15 条回复
xyxfly 2006年10月17日
select dkkbm,val1-(select txje from pjtx_query
where PJZT = 2) from (select DKKBM,SUM(CAST(TXJE AS DECIMAL(12,2)))AS VAL1
FROM pjtx_query
WHERE (PJZT = 1)
GROUP BY DKKBM
)a
这样?
回复 点赞
xyxfly 2006年10月17日
我不是说这个意思

你这个

select DKKBM,SUM(CAST(TXJE AS DECIMAL(12,2)))AS VAL1
FROM pjtx_query
WHERE (PJZT = 1)
GROUP BY DKKBM

只是没有满足减去PJZT = 2的?
回复 点赞
oceanaut 2006年10月17日
TXJE 填写金额 varchar
PJZT 评级状态 varchar
也就是这两个关键的字段,其他几十个字段就暂时没有用到。
回复 点赞
xyxfly 2006年10月17日
搞晕了,你给点数据,说一下你要的结果吧 ^0^
回复 点赞
xyxfly 2006年10月17日

select dkkbm,val1-(select txje from pjtx_query
where PJZT = 2) from (select DKKBM,SUM(CAST(TXJE AS DECIMAL(12,2)))AS VAL1
FROM pjtx_query
WHERE (PJZT = 1)
GROUP BY DKKBM
)a

回复 点赞
xyxfly 2006年10月17日
大概知道你意思了,哪个字段表示状态呢? 表的字段类型又是什么?最好给点数据
回复 点赞
oceanaut 2006年10月17日
PJZT 表示状态
回复 点赞
xyxfly 2006年10月17日
哪个字段表示状态
回复 点赞
oceanaut 2006年10月17日
这里还牵扯到数据类型转换:
select DKKBM,SUM(CAST(TXJE AS DECIMAL(12,2))) AS VAL1
FROM pjtx_query
WHERE (PJZT = 1)
GROUP BY DKKBM

我是这么写的,但还是不对,你帮修改一下。谢谢!
回复 点赞
oceanaut 2006年10月17日
当PJZT=1时,将查询结果中的状态=1的数据加起来;并且减去其中状态=2的数据(状态等于2的数据只有一条)。
回复 点赞
xyxfly 2006年10月17日
上面并没有改你字段啊


把你最终要的结果列一下,就以我建的数据为准吧,好测试
回复 点赞
xyxfly 2006年10月17日
??
回复 点赞
oceanaut 2006年10月17日
谢谢你的回复!
上面:DKKBM改字段只是用来显示在查询结果中
TXJE 时真正要统计的,统计条件根据PJZT来判断(状态为1,2)
回复 点赞
xyxfly 2006年10月17日
create table pjtx_query(DKKBM int,TXJE int,PJZT int)
insert pjtx_query
select 1,1,1 union all
select 2,2,1 union
select 3,3,1 union
select 1,1,2


select sum(case PJZT when 1 then DKKBM
when 2 then -DKKBM end),
sum(case PJZT when 1 then TXJE
when 2 then -TXJE end)
from pjtx_query


drop table pjtx_query

上面的多了个when
回复 点赞
xyxfly 2006年10月17日
select sum(case when PJZT when 1 then DKKBM
when 2 then -DKKBM end),
sum(case when PJZT when 1 then TXJE
when 2 then -TXJE end)
from pjtx_query
?
回复 点赞
发动态
发帖子
MS-SQL Server
创建于2007-09-28

1.4w+

社区成员

25.3w+

社区内容

MS-SQL Server相关内容讨论专区
社区公告
暂无公告