生成交叉表的简单通用存储过程

原创 2004年06月25日 08:41:00

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_qry]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_qry]
GO

/*--生成交叉表的简单通用存储过程
 
 根据指定的表名,纵横字段,统计字段,自动生成交叉表
 并可根据需要生成纵横两个方向的合计

 注意,横向字段数目如果大于纵向字段数目,将自动交换纵横字段
 如果不要此功能,则去掉交换处理部分

--邹建 204.06(引用请保留此信息)--*/

/*--调用示例

 exec p_qry 'syscolumns','id','colid','colid',1,1
--*/

create proc p_qry
@TableName sysname, --表名
@纵轴 sysname,  --交叉表最左面的列
@横轴 sysname,  --交叉表最上面的列
@表体内容 sysname, --交叉表的数数据字段
@是否加横向合计 bit,--为1时在交叉表横向最右边加横向合计
@是否家纵向合计 bit --为1时在交叉表纵向最下边加纵向合计
as
declare @s nvarchar(4000),@sql varchar(8000)

--判断横向字段是否大于纵向字段数目,如果是,则交换纵横字段
set @s='declare @a sysname
if(select case when count(distinct ['+@纵轴+'])from ['+@TableName+'])=1
 select @a=@纵轴,@纵轴=@横轴,@横轴=@a'
exec sp_executesql @s
 ,N'@纵轴 sysname out,@横轴 sysname out'
 ,@纵轴 out,@横轴 out

--生成交叉表处理语句
set @s='
set @s=''''
select @s=@s+'',[''+cast(['+@横轴+'] as varchar)+'']=sum(case ['+@横轴
 +'] when ''''''+cast(['+@横轴+'] as varchar)+'''''' then ['+@表体内容+'] else 0 end)''
from ['+@TableName+']
group by ['+@横轴+']'
exec sp_executesql @s
 ,N'@s varchar(8000) out'
 ,@sql out

--是否生成合计字段的处理
declare @sum1 varchar(200),@sum2 varchar(200),@sum3 varchar(200)
select @sum1=case @是否加横向合计
  when 1 then ',[合计]=sum(['+@表体内容+'])'
  else '' end
 ,@sum2=case @是否家纵向合计
  when 1 then '['+@纵轴+']=case grouping(['
   +@纵轴+']) when 1 then ''合计'' else cast(['
   +@纵轴+'] as varchar) end'
  else '['+@纵轴+']' end
 ,@sum3=case @是否家纵向合计
  when 1 then ' with rollup'
  else '' end

--生成交叉表
exec('select '+@sum2+@sql+@sum1+'
from ['+@TableName+']
group by ['+@纵轴+']'+@sum3)
go

 

sql 交叉表 个存储过程

交叉表啊 创建一个存储过程 看一下以前的帖子CREATE PROCEDURE RobinCrossTable --交叉表生成器--(Select Distinct SuppCode As SCode,...
  • gsong
  • gsong
  • 2007-06-14 17:00:00
  • 825

SqlServer生成交叉表大全

 SqlServer如何生成动态交叉表查询VB+MS SqlServer,是我们目前开发数据库应用系统最常用的模式,翻翻以前的老帖子,有一些SqlServer的问题经常被提出来,但正确解答甚少,现把我...
  • cngkqy
  • cngkqy
  • 2007-12-05 16:39:00
  • 12733

Mysql5 实现交叉表查询

交叉表、行列转换和交叉查询经典 一、什么是交叉表 “交叉表”对象是一个网格,用来根据指定的条件返回值。数据显示在压缩行和列中。这种格式易于比较数据并辨别其趋势。它由三个元素组成:     行...
  • a437629292
  • a437629292
  • 2015-12-15 17:04:17
  • 2179

mysql 查询拓展 触发器 交叉表 存储过程

SHOW TRIGGERS; DROP TRIGGER insertUser DROP TRIGGER deleteUser; DROP TRIGGER updateUser;CREATE TRIGG...
  • ci2011ss
  • ci2011ss
  • 2014-06-26 09:41:23
  • 736

mysql存储过程(递归,交叉表)

1.递归DELIMITER $$;DROP PROCEDURE IF EXISTS `rentmgr`.`tmp`$$/****************************************...
  • fjfdszj
  • fjfdszj
  • 2009-02-20 23:06:00
  • 1594

SQL存储过程实现SPSS交叉表(有图有真相)

SP代码: /****** Object: StoredProcedure [dbo].[Pro_CrossTable] Script Date: 03/27/2014 20:46:38 ...
  • zhouhaiqing0905
  • zhouhaiqing0905
  • 2014-03-27 20:51:53
  • 1540

交叉表 通用存储过程

CREATE   proc   p_qry     @TableName   sysname,   --表名     @纵轴   sysname,     --交叉表最左面的列     @横轴   s...
  • fanzhonglei
  • fanzhonglei
  • 2008-04-18 17:37:00
  • 485

交叉统计报表存储过程的实现

用了2个小时写的下面的过程,供大家学习与交流,并且测试通过,不过代码写的很冗余.大家自己优化一下就OK了下面的存储过程是根据具体的要求来写的,你也可以根据自己的要求重新写,如果你对各种复杂的交叉报表有...
  • feier2004
  • feier2004
  • 2007-05-17 17:08:00
  • 1069

生成交叉表的简单通用存储过程

if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[p_qry]) and OBJECTPROPERTY(id, ...
  • zjcxc
  • zjcxc
  • 2004-06-25 08:41:00
  • 4591

使用MySQL存储过程创建动态交叉表(2)

A mail from the Wizard himself      What an honour: Only hours after publishing my blog entry on dyn...
  • gengv
  • gengv
  • 2009-06-19 23:40:00
  • 674
收藏助手
不良信息举报
您举报文章:生成交叉表的简单通用存储过程
举报原因:
原因补充:

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