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

bukebuhao 2008-11-21 10:21:10
最好推荐几本相关的书,比较经典的
...全文
217 20 打赏 收藏 转发到动态 举报
AI 作业
写回复
用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
  • 打赏
  • 举报
回复
顶一下
《概率论与数理统计》是理工科大学中的一门重要基础课程,它结合了概率论的基本理论与统计学的方法,用于分析和处理随机现象。第二版的完整版多媒体教学系统旨在通过丰富的教学资源和互动体验,帮助学生深入理解和掌握这门学科的核心概念。 一、概率论基础 概率论是研究随机事件及其规律性的数学理论,主要包括以下几个关键概念: 1. 随机试验:概率论的研究对象,如掷骰子、抽卡等。 2. 样本空间:所有可能结果的合。 3. 事件:样本空间的子,代表某种特定的结果。 4. 概率:事件发生的可能性,通常介于0和1之间,表示为P(A)。 5. 条件概率:在已知某个事件发生的情况下,另一个事件发生的概率。 6. 乘法法则和加法法则:用于计算两个独立或不独立事件的概率。 二、概率分布 1. 离散概率分布:如二项分布、泊松分布、几何分布、超几何分布等,用于描述离散随机变量的分布情况。 2. 连续概率分布:如均匀分布、正态分布、指数分布等,适用于连续随机变量。 三、统计学基础 1. 参数估计:通过样本数据估计总体参数,如均值、方差等。 2. 抽样分布:统计量在多次重复抽样下的分布情况。 3. 点估计和区间估计:给出参数的一个估计值或一个估计范围。 4. 假设检验:检验关于总体参数的假设是否成立,如t检验、卡方检验、F检验等。 5. 回归分析:研究两个或多个变量间的关系,预测一个变量基于其他变量的值。 四、数理统计方法 1. 最大似然估计:寻找使样本数据出现概率最大的参数估计方法。 2. 矩估计:通过总体矩与样本矩的关系来估计参数。 3. 正态分布的中心极限定理:大量独立随机变量的和近似服从正态分布,即使这些变量本身非正态。 4. 协方差和相关系数:衡量两个随机变量之间线性关系的强度和方向。 5. 方差分析(ANOVA):比较多个组别间的均值差异。 五、多元统计分析 1. 多元正态分布:多维空间中的正态分布,常用于多元线性回归。 2. 判别分析:根据已知分类的样本数据,建立判别函数,对新数据进行分类。 3. 聚类分析:将相似数据分组,揭示数据内在结构。 4. 主成分分析(PCA):降低数据维度,提取主要特征。 六、多媒体教学系统 该教学系统可能包含以下组成部分: 1. 视频讲座:专家讲解理论和例题,直观展示概念。 2. 动画演示:动态模拟随机过程,帮助理解概率模型。 3. 交互式练习:提供习题和答案,实时反馈学习效果。 4. 实验教程:设计数学实验,让学生亲手操作,加深理解。 5. 电子教材:包含文字、图表、案例等丰富内容,便于自主学习。 通过这个多媒体教学系统,学生不仅可以学习到概率论与数理统计的理论知识,还能通过实践应用和互动学习,提升解决实际问题的能力。

34,871

社区成员

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

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