存储过程不能返回结果集,是因为我查询的是临时表?

bukebuhao 2008-11-21 10:21:10
最好推荐几本相关的书,比较经典的
...全文
205 20 打赏 收藏 转发到动态 举报
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
bukebuhao 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 15 楼 hyde100 的回复:]
引用 14 楼 bukebuhao 的回复:
引用 13 楼 szx1999 的回复:
引用 10 楼 bukebuhao 的回复:
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?


#T:局部临时表,局限于当前会话范围,当前会话关闭,#T即自动消失。
##T:全局临时表,所有会话能同…
[/Quote]

我贴出来,大家看看



ALTER PROCEDURE [dbo].[tuc_process]
@truckName varchar(16),--卡车的名称
@startTime varchar(20), --开始时间
@endTime varchar(20), --结束时间
@timeLimit int, --时间限制
@retuleFlag int output --结果返回判定 0 有车无key, 1 无数据 2 有数据
AS
BEGIN
SET NOCOUNT ON
--临时表
if object_id('tempdb..##tempTruck') > 0 drop table ##tempTruck
--卡车gps里的key
declare @srcTarget varchar(16)
select @srcTarget = SIMID from VehileTable v where v.VehileMark = @truckName
--卡车的key不存在
if @srcTarget is not null
BEGIN
--卡车的记录
SELECT
[SrcTarget],
[GPS_UTC]into ##tempTruck
FROM Track t
where t.srcTarget = @srcTarget and t.GPS_UTC >= @startTime and t.GPS_UTC <= @endTime

if exists(select top 1 SrcTarget from ##tempTruck)
BEGIN
insert into ##tempTruck values(@srcTarget, @startTime)
insert into ##tempTruck values(@srcTarget, @endTime)


select a.currentDate, a.afterDate, datediff(s,a.currentDate,a.afterDate) as timeLimit from (select
t.SrcTarget,
t.GPS_UTC as currentDate,
isnull((select top 1 GPS_UTC from ##tempTruck where SrcTarget = t.SrcTarget and GPS_UTC>t.GPS_UTC order by GPS_UTC ), t.GPS_UTC) as afterDate
from ##tempTruck t) a where datediff(s,a.currentDate,a.afterDate) > @timeLimit
--drop table ##tempTruck
set @retuleFlag = 2
END
else
set @retuleFlag = 1
END
else
set @retuleFlag = 0
SET NOCOUNT OFF
END

水族杰纶 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 bukebuhao 的回复:]
引用 13 楼 szx1999 的回复:
引用 10 楼 bukebuhao 的回复:
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?


#T:局部临时表,局限于当前会话范围,当前会话关闭,#T即自动消失。
##T:全局临时表,所有会话能同时访问,当最后一个对它的引用断…
[/Quote]
exec('select * into #T from test ; select * from #T')
/*序号 value
----------- -----------
1 1
2 2
3 3
4 4
5 5*/
hyde100 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 bukebuhao 的回复:]
引用 13 楼 szx1999 的回复:
引用 10 楼 bukebuhao 的回复:
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?


#T:局部临时表,局限于当前会话范围,当前会话关闭,#T即自动消失。
##T:全局临时表,所有会话能同时访问,当最后一个对它的引用断…
[/Quote]
你的问题太泛泛,应该把你的语句帖出来看看,看你怎么操作的
bukebuhao 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 szx1999 的回复:]
引用 10 楼 bukebuhao 的回复:
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?


#T:局部临时表,局限于当前会话范围,当前会话关闭,#T即自动消失。
##T:全局临时表,所有会话能同时访问,当最后一个对它的引用断开时,##T才自动清除。

单…
[/Quote]

如何实现局部临时表,也可返回结果集?
等不到来世 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 bukebuhao 的回复:]
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?
[/Quote]

#T:局部临时表,局限于当前会话范围,当前会话关闭,#T即自动消失。
##T:全局临时表,所有会话能同时访问,当最后一个对它的引用断开时,##T才自动清除。

单用户应用程序可用##T,
多用户同时操作会导致错误,应避免使用##T,而应考虑其他方案。
水族杰纶 2008-11-21
  • 打赏
  • 举报
回复
临时表有两种类型:     

本地临时表
以一个井号 (#) 开头的那些表名。只有在创建本地临时表的连接上才能看到这些表。

全局临时表
以两个井号 (##) 开头的那些表名。在所有连接上都能看到全局临时表。如果在创建全局临时表的连接断开前没有显式地除去这些表,那么只要所有其它任务停止引用它们,这些表即被除去。当创建全局临时表的连接断开后,新的任务不能再引用它们。当前的语句一执行完,任务与表之间的关联即被除去;因此通常情况下,只要创建全局临时表的连接断开,全局临时表即被除去。
hyde100 2008-11-21
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 bukebuhao 的回复:]
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
引用 3 楼 wufeng4552 的回复:
把局部臨時表改寫為全局臨時表

#T -->##T

这样就可啦,昨晚费了很久,不明白为何这样?
[/Quote]
##T 是全局临时变量,用的时候要小心
bukebuhao 2008-11-21
  • 打赏
  • 举报
回复
我的是在查询分析器里可以,在java程序里得不到结果集合,我的存储过程是有输出参数,我改写成
[Quote=引用 3 楼 wufeng4552 的回复:]
把局部臨時表改寫為全局臨時表

#T -->##T
[/Quote]
这样就可啦,昨晚费了很久,不明白为何这样?
hyde100 2008-11-21
  • 打赏
  • 举报
回复
可以研究下MSDN
  • 打赏
  • 举报
回复

create proc p1
as
select * into # from sysobjects
select * from #

结果一样
fcuandy 2008-11-21
  • 打赏
  • 举报
回复
关注
  • 打赏
  • 举报
回复

create proc p1
as
select * from sysobjects

exec p1

sysobjects 1 S 1 25 -536870909 96 0 0 2000-08-06 01:29:12.717
sysindexes 2 S 1 29 -536870907 32 0 0 2000-08-06 01:29:12.717
syscolumns 3 S 1 32 -536870909 80 0 0 2000-08-06 01:29:12.717
systypes 4 S 1 20 -536870909 80 0 0 2000-08-06 01:29:12.717
syscomments 6 S 1 10 -536870911 48 0 0 2000-08-06 01:29:12.717

…………
super_iven 2008-11-21
  • 打赏
  • 举报
回复
临时表也可以返回数据集
wzy_love_sly 2008-11-21
  • 打赏
  • 举报
回复
看诌键老大的就很好
http://product.dangdang.com/product.aspx?product_id=20165951
水族杰纶 2008-11-21
  • 打赏
  • 举报
回复
把局部臨時表改寫為全局臨時表

#T -->##T
wzy_love_sly 2008-11-21
  • 打赏
  • 举报
回复
结果集?能select 就能返回
hyde100 2008-11-21
  • 打赏
  • 举报
回复
查询临时表也是可以返回数据集的,除非你零时表里没有数据
bukebuhao 2008-11-21
  • 打赏
  • 举报
回复
不过,我搞定啦,呵呵,主要是java程序有问题,调用的时候,ResultSet是执行一次,再执行其他的操作就关闭啦。呵呵
tjg5202 2008-11-21
  • 打赏
  • 举报
回复
学习一下。。。。
bukebuhao 2008-11-21
  • 打赏
  • 举报
回复
顶一下

34,590

社区成员

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

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