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

海洋‘s 2006-10-17 09:26:07
在MS SQL Server中:如何统计状态一样的数据并减去另外一个状态的数据
pjtx_query字段:DKKBM,TXJE,PJZT

当PJZT=1时,将表中所有状态=1的数据加起来;并且减去其中状态=2的数据
(状态等于2的数据只有一条)
请写出具体的sql语句,谢谢!
...全文
236 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
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的?
海洋‘s 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
  • 打赏
  • 举报
回复
大概知道你意思了,哪个字段表示状态呢? 表的字段类型又是什么?最好给点数据
海洋‘s 2006-10-17
  • 打赏
  • 举报
回复
PJZT 表示状态
xyxfly 2006-10-17
  • 打赏
  • 举报
回复
哪个字段表示状态
海洋‘s 2006-10-17
  • 打赏
  • 举报
回复
这里还牵扯到数据类型转换:
select DKKBM,SUM(CAST(TXJE AS DECIMAL(12,2))) AS VAL1
FROM pjtx_query
WHERE (PJZT = 1)
GROUP BY DKKBM

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


把你最终要的结果列一下,就以我建的数据为准吧,好测试
xyxfly 2006-10-17
  • 打赏
  • 举报
回复
??
海洋‘s 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
?

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧