数据库中多条不同数据的统计时组织成一张表

今天在做数据库的存储过程的时候碰到了一个问题,我想对数据库中多天不同类别的数据量分别进行统计后一起传出来,刚开始我写的是以下Sql语句:

 

 1 SELECT COUNT(*) as WaitWork from
2 SUDS_Work_Submit where File_Mark=0 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)
3 SELECT COUNT(*) as FinishedWork from
4 SUDS_Work_Submit where File_Mark=3 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)
5 SELECT COUNT(*) as WaitCheck from
6
7 SUDS_Work_Submit where File_Mark=1 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)
8 SELECT COUNT(*) as BackWork from
9 SUDS_Work_Submit where File_Mark=2 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)
10
11 END




这段代码在执行时并没有错误,但数据传出去的时候并不是以一张表的形式传出去的,而是以多张表的形式,这样就会造成无法将这些统计的多个数据量转换成DataTable表,从而会导致列名在数据表中无效,解决办法将这几个统计数据量组织成一张表的形式传出来。改进后的Sql语句如下:

 1 select (SELECT COUNT(*) as WaitWork from
2 SUDS_Work_Submit where File_Mark=0 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)) as WaitWork,
3
4
5 (SELECT COUNT(*) as FinishedWork from
6 SUDS_Work_Submit where File_Mark=3 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)) as FinishedWork,
7
8
9 (SELECT COUNT(*) as WaitCheck from
10 SUDS_Work_Submit where File_Mark=1 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)) as WaitCheck,
11
12
13 (SELECT COUNT(*) as BackWork from
14 SUDS_Work_Submit where File_Mark=2 and Staff_ID=(select UserID from Accounts_Users where UserName=@StaffName)) as BackWork
15 END


转载于:https://www.cnblogs.com/xiaopanlyu/archive/2012/02/23/2365264.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值