用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > sqlserver教程

在SQL Server中创建全局临时表技巧

时间:2014-11-30  来源:互联网  作者:佚名

全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。例如,如果你在存储过程中创建全局临时表,当超出存储过程的范围时,该表并不会被销毁。当创建会话终止后,SQL(SQL Server培训 mySQL培训 ) Server才会自动尝试删除该表,其他会话中对其提交的所有语句都将结束,并释放它们所保持的所有锁。

但在某些情况下,你可能想创建一个不属于任何会话的全局临时表。这时,无论哪个会话打开或关闭,它总数存在,只有显式的删除它才能被移除。为此,可以在一个特殊的存储过程中(使用sp_前缀,在master中创建)创建该表并使用“startup”选项标记该存储过程。Sql Server会在每次启动时调用启动过程(startup procedure)。而且,Sql Server为启动过程中创建的全局临时表维护一个大于0的引用计数器,这样就确保Sql Server不会尝试自动删除它。

如下所示:

USE master;

GO

IF OBJECT_ID('dbo.sp_Globals') IS NOT NULL

DROP PROC dbo.sp_Globals

GO

CREATE proc dbo.sp_Globals

AS

CREATE TABLE ##Globals

(

id varchar(36) NOT NULL PRIMARY KEY,

value varchar(500)

);

GO

EXEC dbo.sp_procoption 'dbo.sp_Globals','startup','true';

执行并重启Sql Server后,全局临时表##Globals会自动重建并一直持续到被显式删除。

详解SQL Server 2008迁移查询计划

MySQL数据库接口的VC实现与应用

SQL Server 2005常见问题浅析

来顶一下
返回首页
返回首页
推荐资讯
从零开始学ASP.NET-基础篇第1/7页 从零开始学ASP.NET-基础篇第1/7页第一天 学习目的: 掌握最基本的Label、TextBox、Button控件
ASP.NET入门数据篇 ASP.NET入门数据篇对于网站编程的初学者来说,总是会上网找些源码来看,但久而
相关文章
栏目更新
栏目热门