交叉报表处理实例

原创 2005年05月31日 16:21:00

两种比较特殊的交叉数据报表处理

--示例数据:
CREATE TABLE tb(ID varchar(10),NGNO char(1),QTY int)
INSERT tb SELECT '200505','A',10
UNION ALL SELECT '200505','B',20
UNION ALL SELECT '200505','C',30
UNION ALL SELECT '200506','B',10
UNION ALL SELECT '200506','C',20
UNION ALL SELECT '200506','D',30
UNION ALL SELECT '200506','E',40
GO

交叉数据报表要求1:
    按ID列分组,将NGNO列水平显示为多列,但每列由NGNO的大小顺序决定,而不是由NGNO的值决定,对于示例数据,最终的结果要求如下:

ID         col1    col2    col3    col4
---------- ------- ------- ------- -------
200505     A(10)   B(20)   C(30)   
200506     B(10)   C(20)   D(30)   E(40)

--实现代码
DECLARE @i varchar(10),@s nvarchar(4000)
SELECT TOP 1 @s='',@I=COUNT(*) FROM tb
GROUP BY ID
ORDER BY COUNT(*) DESC
WHILE @i>0
SELECT @s=N',col'+@i
        +N'=ISNULL(MAX(CASE GID WHEN '+@i
        +N' THEN QTY END),'''')'+@s,
    @i=@i-1
EXEC(N'SELECT ID'+@s+N'
FROM(
    SELECT ID,QTY=RTRIM(NGNO)+QUOTENAME(QTY,N''()''),
    GID=(SELECT COUNT(DISTINCT NGNO) FROM TB WHERE ID=a.ID AND NGNO<=a.NGNO)
    FROM tb a
)a GROUP BY ID')
GO

交叉数据报表要求2:
    按ID列分组,将NGNO及QTY列合并显示在一个列中,最终的结果要求如下:

ID         Value
---------- -----------------------------------------------
200505     A(10)        B(20)        C(30)
200506     B(10)        C(20)        D(30)        E(40)

(所影响的行数为 2 行)

--实现处理的函数
CREATE FUNCTION f_Str(@ID varchar(10))
RETURNS varchar(8000)
AS
BEGIN
    DECLARE @r varchar(8000)
    SET @r=''
    SELECT @r=@r+SPACE(8)+RTRIM(NGNO)+QUOTENAME(QTY,'()')
    FROM tb
    WHERE ID=@ID
    RETURN(STUFF(@r,1,8,''))
END
GO

--调用实现查询
SELECT ID,Value=dbo.f_Str(ID) FROM tb GROUP BY ID
GO

原帖地址

交叉报表处理实例

两种比较特殊的交叉数据报表处理 --示例数据:CREATE TABLE tb(ID varchar(10),NGNO char(1),QTY int)INSERT tb SELECT 200505,A...
  • chenzhiya
  • chenzhiya
  • 2008年01月03日 14:52
  • 217

用Birt 制作交叉报表

1>我们先建立一个简单的数据库模型,虽然说简单,但是为了后期扩展,尽量将表设计更加细些. 但是,在本例中,我们只用到我们所关心的表.截图如下(图一目了然我就不多说了): 我们将数据库模型导出脚...
  • xiaocha2008
  • xiaocha2008
  • 2011年09月13日 16:45
  • 3534

SpingMVC IReport多数据源交叉报表示例

开始本示例之前,有必要先阅读我先前发布的《SpringMVC与iReport(JasperReports) 5.6整合开发实例》这篇博文,只有熟悉了SpringMVC与iReport的整合基础之后,才...
  • xht555
  • xht555
  • 2015年11月08日 14:13
  • 4659

一个动态交叉分片报表的几种实现方法

http://blog.runqian.com.cn/?p=1382 动态列报表在报表应用中很常见,往往由于业务的不同复杂度也差异很大。复杂的动态列报表在实现上往往十分困难,常见于数据源准备...
  • raqreport
  • raqreport
  • 2016年04月11日 17:20
  • 556

报表例子——用BIRT实现不规则月份统计

来源:     http://developer.actuate.com/community/forum/index.php?/topic/36323-months-and-quarters-grou...
  • u012388497
  • u012388497
  • 2015年07月17日 09:45
  • 1022

如何利用FastReport创建交叉报表?

转自:http://www.fastreportcn.com/Article/92.html 本文我们将创建一个交叉报表,用于显示员工四年中的工资。要创建交叉报表,我们需要使用到Fa...
  • cw370008359
  • cw370008359
  • 2014年12月11日 13:24
  • 1120

用iReport制作一个简单的交叉报表

1、  打开iReport软件,【文件】——>【New】,选择一个报表模版,(以选择第一个模版为例),然后选择“Open this Template”, 如图1.1所示。进入下一个页面,填写文件...
  • liuxiyangyang
  • liuxiyangyang
  • 2012年12月24日 16:10
  • 8321

【PB】提取动态交叉报表动态标题名和动态列值

//提取动态交叉报表动态标题名和动态列值: String ls_Str, ls_Str1, ls_Name, ls_Name_Text, ls_Text Long ll_Cnt, ...
  • lijianhe043
  • lijianhe043
  • 2016年09月12日 17:52
  • 1473

Ireport交叉报表

1、构造数据源: package test; import java.util.ArrayList; public class CrossReportFactory { pu...
  • cbjcry
  • cbjcry
  • 2017年04月13日 10:27
  • 368

转:邹建--交叉报表处理实例

转: http://writeblog.csdn.net/PostEdit.aspx两种比较特殊的交叉数据报表处理 --示例数据:CREATE TABLE tb(ID varchar(10),NGNO...
  • flyskylf
  • flyskylf
  • 2007年12月25日 14:00
  • 404
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:交叉报表处理实例
举报原因:
原因补充:

(最多只允许输入30个字)