免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 7555 | 回复: 5
打印 上一主题 下一主题

求助MYSQL交叉报表 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-22 23:21 |只看该作者 |倒序浏览
表结构是
id xswd xsmc xsje xsje2 xsje3
序号 销售网点 销售产品名称 金额 买单 奖励
1 网点1 A 1 2 5
2 网点2 B 2 6 8
3 网点3 C 4 1 6
4 网点1 B 16 66 66
能不能取数变成这样的交叉报表


A 买单 奖励 B 买单 奖励 C 买单 奖励
网点1 1 2 5 16 66 66 0 0 0
网点2 2 6 8 0 0 0 0 0 0
网点3

网点金额 买单取合计数

我上网查了很多看到一个文章,但运行出错不知道错在那里
SET @EE='';
SELECT @EE:=CONCAT(@EE,'SUM(IF(xsmc=/'',xsmc,'/'',',xsje,0)) AS ',xsmc,',') FROM (SELECT DISTINCT xsmc FROM jjxs) A;
SET @QQ=CONCAT('SELECT ifnull(xswd,/'total/'),',LEFT(@EE,LENGTH(@EE)-1),' ,SUM(xsje) AS TOTAL FROM xsmc GROUP BY xswd WITH ROLLUP');
PREPARE stmt2 FROM @QQ;

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
2 [报告]
发表于 2013-09-23 09:59 |只看该作者
你那数据格式不好看啊,有没有空格什么的看不出来,数据或者使用代码框框起来,或者使用附件提供。

另外,你的语句运行出错,报什么错呢,要贴出来。

最后,这个就是普通的“列转行”的问题,你可以搜索相关的内容参考,实在不行的时候,把表结构和数据附上,方便大家帮忙测试。

论坛徽章:
0
3 [报告]
发表于 2013-10-03 09:14 |只看该作者
有个报表工具,grid++report做交叉表很方便,http://video.sina.com.cn/v/b/112738927-2697789081.html这里有个视频,前面是数据介绍,从5分45秒开始具体将怎么操作。

论坛徽章:
0
4 [报告]
发表于 2013-10-12 11:49 |只看该作者
如果只有3个网点,我觉得你可以先分组计算,然后在EXCEL中转置,应该可以达到这个效果。

论坛徽章:
0
5 [报告]
发表于 2013-10-12 13:52 |只看该作者
SELECT xsmd,sum(CASE WHEN xsmc='A' THEN xsje ELSE 0 END) Axsje,sum(CASE WHEN xsmc='A' THEN xsje1 ELSE 0 END) Axsje1,sum(CASE WHEN xsmc='A' THEN xsje2 ELSE 0 END) Axsje2,
sum(CASE WHEN xsmc='B' THEN xsje ELSE 0 END) Bxsje,sum(CASE WHEN xsmc='B' THEN xsje1 ELSE 0 END) Bxsje1,sum(CASE WHEN xsmc='B' THEN xsje2 ELSE 0 END) Bxsje2,
sum(CASE WHEN xsmc='C' THEN xsje ELSE 0 END) Cxsje,sum(CASE WHEN xsmc='C' THEN xsje1 ELSE 0 END) Cxsje1,sum(CASE WHEN xsmc='C' THEN xsje2 ELSE 0 END) Cxsje2
FROM
(SELECT xsmd,xsmc,SUM(xsje) xsje,SUM(xsje1) xsje1,SUM(xsje2) xsje2 FROM 表名  GROUP BY 1,2) cm GROUP BY 1;

论坛徽章:
0
6 [报告]
发表于 2013-10-12 13:53 |只看该作者
SELECT xsmd,sum(CASE WHEN xsmc='A' THEN xsje ELSE 0 END) Axsje,sum(CASE WHEN xsmc='A' THEN xsje1 ELSE 0 END) Axsje1,sum(CASE WHEN xsmc='A' THEN xsje2 ELSE 0 END) Axsje2,
sum(CASE WHEN xsmc='B' THEN xsje ELSE 0 END) Bxsje,sum(CASE WHEN xsmc='B' THEN xsje1 ELSE 0 END) Bxsje1,sum(CASE WHEN xsmc='B' THEN xsje2 ELSE 0 END) Bxsje2,
sum(CASE WHEN xsmc='C' THEN xsje ELSE 0 END) Cxsje,sum(CASE WHEN xsmc='C' THEN xsje1 ELSE 0 END) Cxsje1,sum(CASE WHEN xsmc='C' THEN xsje2 ELSE 0 END) Cxsje2
FROM test.yang_test1 GROUP BY 1;
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP