一个可能大家都遇到过的问题。

Judges 2003-11-11 12:08:31
问题是这样的:有表A,里面的内容是产品的分类,表B,里面的内容是客户id,产品分类id,成交金额,成交日期。
现在我需要出一张报表,内容是统计一段时间内每个客户各个产品的成交金额。
也就象这样:
表A:
id type_name
1 test1
2 test2
3 test3
表B:
id type_id cmp_id money date
1 1 1 20 2003-10-12
2 1 1 30 2003-10-15
...
...
...
90 3 34 900 2003-11-15

报表是这样的
编号 公司名称 test1 test2 test3 合计
1 1 ×× 0 0
...
...
...
n n ××
合计 — ×× ×× ×× ××

不知道各位有什么好的方案没有,主要是表A的内容可能会发生变化的!
...全文
32 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
Judges 2003-11-11
  • 打赏
  • 举报
回复
多谢楼上的两位,我试过以后回来加分,谢谢!
shuiniu 2003-11-11
  • 打赏
  • 举报
回复
declare @sql varchar(8000)
set @sql = 'select 公司名称'
select @sql = @sql + ',sum(case id when '+ cast(type_id as varchar) +' then money else 0 end) ['+ type_name +']'
from 表A
select @sql = @sql+' from 表B group by 公司名称 order by 公司名称 desc'
exec(@sql)
txlicenhe 2003-11-11
  • 打赏
  • 举报
回复
http://expert.csdn.net/Expert/topic/2440/2440306.xml?temp=.6941645
[交流]行列转换
zjcxc 元老 2003-11-11
  • 打赏
  • 举报
回复
--改执行的语句:

exec('select 编号=a.cmp_id
,公司名称=case when grouping(b.name)=1 then ''-合计-'' else b.name end'
+@s+',合计=sum(money)
from 表b a inner join 表C b on a.cmp_id=b.cmp_id
where date=''2003-01-01''
group by a.cmp_id,b.name with rollup
having grouping(b.name)=0 or grouping(a.cmp_id)=1')
Judges 2003-11-11
  • 打赏
  • 举报
回复
多谢 zjcxc(邹建) 结贴结的早了 呵呵 sorry啊 不过 还有个问题:如果我价格筛选条件,比如时间限制的 该怎么写?
zjcxc 元老 2003-11-11
  • 打赏
  • 举报
回复
根据楼主的数据,做了测试:


--创建数据测试环境
create table 表A(id int,type_name varchar(10))
insert into 表A
select 1,'test1'
union all select 2,'test2'
union all select 3,'test3'

create table 表B(id int,type_id int,cmp_id int,[money] int,date datetime)
insert into 表B
select 1,1,1,20,'2003-10-12'
union all select 2,1,1,30,'2003-10-15'
union all select 3,2,2,32,'2003-10-15'
union all select 4,2,3,33,'2003-10-15'
union all select 3,1,2,52,'2003-10-15'
union all select 4,3,3,63,'2003-10-15'

create table 表C(cmp_id int,name varchar(10))
insert into 表C
select 1,'A公司'
union all select 2,'B公司'
union all select 3,'C公司'
union all select 4,'D公司'
union all select 5,'E公司'

declare @s varchar(8000)
set @s=''
select @s=@s+','+type_name+'=sum(case type_id when '
+cast(id as varchar)+' then [money] else 0 end)'
from 表A
exec('select 编号=a.cmp_id
,公司名称=case when grouping(b.name)=1 then ''-合计-'' else b.name end'
+@s+',合计=sum(money)
from 表b a inner join 表C b on a.cmp_id=b.cmp_id
group by a.cmp_id,b.name with rollup
having grouping(b.name)=0 or grouping(a.cmp_id)=1')
go
drop table 表a,表b,表c
Judges 2003-11-11
  • 打赏
  • 举报
回复
好了 谢谢两位的帮忙!!解决了 不过我要添加筛选的话,怎么写?
zjcxc 元老 2003-11-11
  • 打赏
  • 举报
回复
参考:
http://expert.csdn.net/Expert/topic/2303/2303308.xml?temp=.7622949
lvltt 2003-11-11
  • 打赏
  • 举报
回复
向马可学习
经常使用电脑可能遇到过了! 突然‘咚’的一声 提示 内存不能为read 这个问题我以前也遇到过不知道怎么解决 现在终于有办法了!呵呵! 我们就看看是什么原因引起的吧,另外附送一个小工具修复见下面附件 总结下大概以下9个原因 1、驱动不稳定,与系统不兼容,这最容易出现内存不能为 Read 或者文件保护(主要原因) 2、系统安装了一个或者多个流氓软件,这出现 IE 或者系统崩溃的机会也比较大,也有可能出现文件保护 3、系统加载的程序或者系统正在运行的程序之前有冲突,尤其是部分杀毒软件监控程序 4、系统本身存在漏洞,导致容易受到网络攻击。 5、病毒问题也是主要导致内存不能为 Read、文件保护、Explorer.exe 错误…… 6、如果在玩游戏时候出现内存不能为 Read,则很大可能是显卡驱动不适合(这里的不适合有不适合该游戏、不适合电脑的显卡)也有可能是 系统版本不够新或者不符合该游戏、显卡驱动 7、部分软件本身自身不足的问题 8、电脑硬件过热,也是导致内存不能为 Read 的原因之一。 9、电脑内存与主板兼容性不好也是导致内存不能为 Read 的致命原因! 以上大概就是目前可以引起系统提示 内存不能为read的原因了 另外软件是针对只是针对部分原因引起的内存不为read所做修复,不是100%有效,大家可以试试看 说下原理: 就是批处理使用 regsvr32命令 将动态链接库文件重新注册 (system32下的所有 .dll 和 .ocx 文件;) 注意:由于修复工具会重新注册 system32下的所有 .dll 和 .ocx 文件 此操作对杀毒软件来说属于敏感操作,所以建议使用修复工具的时候,请禁用杀毒软件,以免部分杀毒误报!jie

34,875

社区成员

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

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