存储过程问题?

SuperZhou 2002-04-29 11:17:37
我有一存储过程,里面有一系列的统计SQL语句,最后一句是select * from 表(临时表),在查询分析器中有结果,但在VB中用ADO的RecordSet对象打开该存储过程后,不能取结果,显示RecordSet对象关闭,这是怎么回事?用NextRecordet方法也不行,不知各位遇到这样的问题没有?
...全文
99 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
leimin 2002-04-29
  • 打赏
  • 举报
回复
不应该用RecordSet。要用COMMAND,
RS=COMMAND.EXECUTE
SuperZhou 2002-04-29
  • 打赏
  • 举报
回复
我用的ADO对象,应该是没有问题的,试过好多次了,to jinfeng_Wang(FanS),你做过这个方面的东西吗?
SuperZhou 2002-04-29
  • 打赏
  • 举报
回复
我自己解决解决了,在存储过程开始加上SET NOCOUNT ON就可以了,返回的记录集只有最后一个SELECT的。
greenhope 2002-04-29
  • 打赏
  • 举报
回复
你试试将临时表用##命名看看
SuperZhou 2002-04-29
  • 打赏
  • 举报
回复
存储过程是这样的:
--@StartDatetimetime,@EndDatetime为收费起始和终止日期,
--@TollcenterNo为中心号,@TollgateNo为站号,@TimeFlag为时间标志
CREATE PROCEDURE FluxQuery @StartDatetime datetime,@EndDatetime datetime,
@TollcenterNo varchar(4),@TollgateNo varchar(4),
@TimeFlag char(1)
AS
DECLARE @SQL varchar(1000),@SQL1 varchar(100),@SQL2 varchar(100),@SQL3 varchar(100),
@SQL4 varchar(100),@SQL5 varchar(100)
DECLARE @Datetime1 datetime,@Datetime2 datetime,@Datetime3 datetime,@Datetime4 datetime,
@TempDate datetime
DECLARE @i tinyint,@j tinyint,@MaxDay tinyint

CREATE TABLE #FluxStat
(时间 tinyint,
一类车 int,
二类车 int,
三类车 int,
四类车 int,
五类车 int,
免费 int,
月卡 int,
违章 int)

CREATE TABLE #FluxStat1
(时间 tinyint,
一类车 int,
二类车 int,
三类车 int,
四类车 int,
五类车 int,
免费 int,
月卡 int,
违章 int)

CREATE TABLE #FluxStat2
(时间 tinyint,
车型 char(2),
卡状态 char(2),
流量 int)

IF @TimeFlag='d'
BEGIN
SET @SQL1='SELECT 时间=CAST(passedtime as tinyint)'
SET @SQL3='GROUP BY passedtime ORDER BY passedtime'
SET @SQL4='SELECT 时间=DATEPART(hh,passedtime)'
SET @SQL5='GROUP BY DATEPART(hh,passedtime),cartype,cardstatus'

SET @i=0
WHILE(@i<=23)
BEGIN
INSERT INTO #FluxStat VALUES(@i,0,0,0,0,0,0,0,0)
SET @i=@i+1
END
END
ELSE IF @TimeFlag='m'
BEGIN
SET @SQL1='SELECT 时间=DATEPART(dd,passeddate)'
SET @SQL3='GROUP BY DATEPART(dd,passeddate) ORDER BY DATEPART(dd,passeddate)'
SET @SQL4='SELECT 时间=DATEPART(dd,passedtime)'
SET @SQL5='GROUP BY DATEPART(dd,passedtime),cartype,cardstatus'
--计算月份的最大天数
SET @i=1
SET @MaxDay=DATEPART(dd,@EndDatetime)
WHILE(@i<=DATEDIFF(mm,@StartDatetime,@EndDatetime))
BEGIN
SET @TempDate=DATEADD(mm,@i+1,@StartDatetime)
SET @j=DATEPART(dd,DATEADD(dd,-1,CONVERT(datetime,DATENAME(yy,@TempDate)+'-'+DATENAME(mm,@TempDate)+'-01')))
IF @j>@MaxDay
SET @MaxDay=@j
IF @j=31
BREAK
SET @i=@i+1
END
SET @i=1
WHILE(@i<=@MaxDay)
BEGIN
INSERT INTO #FluxStat VALUES(@i,0,0,0,0,0,0,0,0)
SET @i=@i+1
END

END
ELSE
BEGIN
SET @SQL1='SELECT 时间=DATEPART(mm,passeddate)'
SET @SQL3='GROUP BY DATEPART(mm,passeddate) ORDER BY DATEPART(mm,passeddate)'
SET @SQL4='SELECT 时间=DATEPART(mm,passedtime)'
SET @SQL5='GROUP BY DATEPART(mm,passedtime),cartype,cardstatus'
SET @i=1
WHILE(@i<=12)
BEGIN
INSERT INTO #FluxStat VALUES(@i,0,0,0,0,0,0,0,0)
SET @i=@i+1
END
END

IF @tollcenterno='所有' and @tollgateno='所有'
SET @SQL2=''
ELSE IF @tollcenterno<>'所有' and @tollgateno='所有'
SET @SQL2='AND tollcenterno=''' + @tollcenterno + ''''
ELSE
SET @SQL2='AND tollcenterno=''' + @TollCenterNo + ''' AND tollgateno=''' + @TollgateNo + ''''

IF DATEPART(mi,@StartDatetime)<>0 OR DATEPART(ss,@StartDatetime)<>0
BEGIN
SET @Datetime1=CONVERT(char(10),@StartDatetime,102)+' '+DATENAME(hh,@StartDatetime)+':59:59'
SET @Datetime2=DATEADD(ss,1,@Datetime1)
SET @Datetime4=CONVERT(char(10),@EndDatetime,102)+' ' +DATENAME(hh,@EndDatetime)+':00:00'
SET @Datetime3=DATEADD(ss,-1,@Datetime4)
SET @SQL='INSERT INTO #FluxStat2 '+@SQL4+',车型=cartype,卡状态=cardstatus,流量=count(cartype)
FROM passedcars WHERE (passedtime BETWEEN ''' + CONVERT(varchar(30),@StartDatetime,120)+ ''' AND ''' +
CONVERT(varchar(30),@Datetime1,120)+ ''' OR passedtime BETWEEN ''' + CONVERT(varchar(30),@Datetime4,120)+
''' AND ''' + CONVERT(varchar(30),@EndDatetime,120)+''') '+ @SQL2 + ' ' +@SQL5
EXECUTE(@SQL)

INSERT INTO #FluxStat1 SELECT 时间,SUM(CASE WHEN 车型='01' and (卡状态='02' or 卡状态='04' or 卡状态='05' or 卡状态='10')
THEN 流量 ELSE 0 END),SUM(CASE WHEN 车型='02' and (卡状态='02' or 卡状态='04' or 卡状态='05' or 卡状态='10')
THEN 流量 ELSE 0 END),SUM(CASE WHEN 车型='03' and (卡状态='02' or 卡状态='04' or 卡状态='05' or 卡状态='10')
THEN 流量 ELSE 0 END),SUM(CASE WHEN 车型='04' and (卡状态='02' or 卡状态='04' or 卡状态='05' or 卡状态='10')
THEN 流量 ELSE 0 END),SUM(CASE WHEN 车型='05' and (卡状态='02' or 卡状态='04' or 卡状态='05' or 卡状态='10')
THEN 流量 ELSE 0 END),SUM(CASE WHEN 卡状态='07' THEN 流量 ELSE 0 END),
SUM(CASE WHEN 卡状态='09' THEN 流量 ELSE 0 END),SUM(CASE WHEN (卡状态='01' or 卡状态='03' or 卡状态='06' or 卡状态='08')
THEN 流量 ELSE 0 END)
FROM #FluxStat2 GROUP BY 时间

UPDATE A
SET A.一类车=A.一类车+B.一类车,A.二类车=A.二类车+B.二类车,A.三类车=A.三类车+B.三类车,
A.四类车=A.四类车+B.四类车,A.五类车=A.五类车+B.五类车,A.免费=A.免费+B.免费,
A.月卡=A.月卡+B.月卡,A.违章=A.违章+B.违章
FROM #FluxStat A,#FluxStat1 B
WHERE A.时间=B.时间
TRUNCATE TABLE #FluxStat1
END
ELSE
BEGIN
SET @Datetime2=@StartDatetime
SET @Datetime3=@EndDatetime
END

SET @SQL='INSERT INTO #FluxStat1 '+@SQL1+',一类车=SUM(flux1),二类车=SUM(flux2),三类车=SUM(flux3)
,四类车=SUM(flux4),五类车=SUM(flux5),免费=SUM(free),月卡=SUM(monthcard)
,违章=SUM(invalidation) FROM daysreport WHERE CONVERT(char(10),passeddate,102)+passedtime>=''' +
CONVERT(char(10),@Datetime2,102)+datename(hh,@Datetime2) +'''' +
' AND CONVERT(char(10),passeddate,102)+passedtime<='''+CONVERT(char(10),@Datetime3,102)+
datename(hh,@Datetime3)+''' '+ @SQL2 + ' ' +@SQL3
EXECUTE(@SQL)

UPDATE A
SET A.一类车=A.一类车+B.一类车,A.二类车=A.二类车+B.二类车,A.三类车=A.三类车+B.三类车,
A.四类车=A.四类车+B.四类车,A.五类车=A.五类车+B.五类车,A.免费=A.免费+B.免费,
A.月卡=A.月卡+B.月卡,A.违章=A.违章+B.违章
FROM #FluxStat A,#FluxStat1 B
WHERE A.时间=B.时间

SELECT 时间,一类车,二类车,三类车,四类车,五类车,免费,月卡,违章,
合计=一类车+二类车+三类车+四类车+五类车+免费+月卡+违章
FROM #FluxStat
GO
brotherfromaq 2002-04-29
  • 打赏
  • 举报
回复
最好不要用set rs=c.execute
用set rs.source=c
....
rs.open
SuperZhou 2002-04-29
  • 打赏
  • 举报
回复
我建的是本地临时表,而且我的连接没有关闭
greenhope 2002-04-29
  • 打赏
  • 举报
回复
不知你的临时表是怎么建的,sql server的临时表有三种情况,一种是本地临时表(#)只在当前连接中可以用,连接关闭了临时表就消失,别的连接不可以访问,一种是全局临时表(##)可以和别人公用的临时表,但当你的连接关闭了,别人就不可以用了,最后一种是直接在TempDB中创建的临时表,可以用于任何连接
SuperZhou 2002-04-29
  • 打赏
  • 举报
回复
试过了,还是不行呀,总是显示记录集关闭了

34,593

社区成员

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

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