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