关于存储过程的问题

liyanfeng1206 2009-02-08 06:10:28
关于存储过程的问题,下面是完成的存储过程,我想再增加一项功能(如红色字体),比如AA是统计满足条件的sumcount字段数字的和,现在想知道满足AA条件的有多少条记录,请高手指点.真诚感谢!
CREATE procedure Corss
@strTabName as varchar(50) = 'XLSPDF',--要处理的数据表
@strCol as varchar(50) = 'AA',--被统计字段类型
@strGroup as varchar(50) = '[ARC Number For Trans]',--分组字段
@strNumber as varchar(50) = 'sumcount', --被统计的字段
@strSum as varchar(10) = 'Sum' --运算方式
@strCount as varchar(10) = 'Count' --新的运算方式

AS
DECLARE @strSql as varchar(1000), @strTmpCol as varchar(100)
EXECUTE ('DECLARE corss_cursor CURSOR FOR SELECT DISTINCT ' + @strCol + ' from ' + @strTabName + ' for read only ') --生成游标
begin
SET nocount ON
SET @strsql ='select ' + @strGroup + ', ' + @strSum + '(' + @strNumber + ') AS [' + @strNumber + ']' --查询的前半段
OPEN corss_cursor
while (0=0)
BEGIN
FETCH NEXT FROM corss_cursor --遍历游标,将列头信息放入变量@strTmpCol
INTO @strTmpCol
if (@@fetch_status<>0) break
SET @strsql = @strsql + ', ' + @strSum + '(CASE ' + @strCol + ' WHEN ''' + @strTmpCol + ''' THEN ' + @strNumber + ' ELSE Null END) AS [' + @strTmpCol + ']' --构造查询
END
SET @strsql = @strsql + ' from ' + @strTabname + ' group by ' + @strGroup --查询结尾
EXECUTE(@strsql) --执行
IF @@error <>0 RETURN @@error --如果出错,返回错误代码
CLOSE corss_cursor
DEALLOCATE corss_cursor RETURN 0 --释放游标,返回0表示成功
end
GO
...全文
84 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
太昊悦和 2009-02-09
  • 打赏
  • 举报
回复
顶4楼
dragonmay2008 2009-02-09
  • 打赏
  • 举报
回复
顶楼上的
xiaofirehu 2009-02-09
  • 打赏
  • 举报
回复
根据AA条件再进行一次查询不行么?
金大哈 2009-02-09
  • 打赏
  • 举报
回复
不清楚你具体要那些条件
改一个如下 看看可符合要求



EXECUTE ('DECLARE corss_cursor CURSOR FOR SELECT DISTINCT ' + @strCol + ' from ' + @strTabName + where '+@strCol+' = '+@strCount+' for read only ') --生成游标


金大哈 2009-02-09
  • 打赏
  • 举报
回复
加个 where 就可以啦
ZKM_ZHANG 2009-02-09
  • 打赏
  • 举报
回复
jf
hearyone 2009-02-09
  • 打赏
  • 举报
回复
学习!

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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