在SQL数据库中创建全局临时表_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

在SQL数据库 中创建全局临时表

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:临时全局创建数据库
黑客防线网安网讯:    提示:全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。例如,如果你在存储过程中创建全局临时表,当超出存储过程的范围时,该表并不会被销毁。当创建会话终止后,Sql Se...

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


全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。例如,如果你在存储过程中创建全局临时表,当超出存储过程的范围时,该表并不会被销毁。当创建会话终止后,Sql Server才会自动尝试删除该表,其他会话中对其提交的所有语句都将结束,并释放它们所保持的所有锁。
  但在某些情况下,你可能想创建一个不属于任何会话的全局临时表。这时,无论哪个会话打开或关闭,它总数存在,只有显式的删除它才能被移除。为此,可以在一个特殊的存储过程中(使用sp_前缀,在master中创建)创建该表并使用“startup”选项标记该存储过程。Sql Server会在每次启动时调用启动过程(startup procedure)。而且,Sql Server为启动过程中创建的全局临时表维护一个大于0的引用计数器,这样就确保Sql Server不会尝试自动删除它。

  如下所示:

 

USE master;GOIF OBJECT_ID('dbo.sp_Globals') IS NOT NULL  DROP PROC dbo.sp_GlobalsGOCREATE proc dbo.sp_GlobalsAS 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会自动重建并一直持续到被显式删除

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-10863-1.html
网站维护教程更新时间:2012-03-21 03:11:32  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer