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

运维 数据库运维 SQL Server
本文将介绍如何在SQL Server中如何创建一个不属于任何会话的全局临时表,以及由此所带来的相关便利。

全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。例如,如果你在存储过程中创建全局临时表,当超出存储过程的范围时,该表并不会被销毁。当创建会话终止后,Sql 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会自动重建并一直持续到被显式删除。

【编辑推荐】

  1. 详解SQL Server 2008迁移查询计划
  2. MySQL数据库接口的VC实现与应用
  3. SQL Server 2005常见问题浅析
责任编辑:彭凡 来源: 新浪博客
相关推荐

2010-07-01 14:46:10

SQL Server临

2011-03-29 13:22:07

SQL Server临时表表变量

2010-09-16 15:03:10

SQL Server临

2010-09-16 17:56:31

SQL server临

2010-07-26 13:56:38

SQL Server临

2010-07-22 16:02:29

2010-10-19 14:45:01

SQL SERVER临

2021-04-29 08:11:11

SQL优化作用

2021-01-18 05:23:14

SQL 排序Server

2023-05-26 16:40:22

临时表Hive数据表存储

2010-09-16 15:10:48

SQL Server表

2010-07-08 14:42:34

SQL Server临

2010-10-19 14:56:05

sql server临

2010-10-19 15:25:05

Sql Server临

2010-07-23 13:42:11

SQL Server临

2010-10-19 15:31:40

sql server触

2010-09-02 16:28:03

SQL删除

2011-09-02 14:45:43

Oracle临时表SQL Server临

2010-07-22 15:56:04

SQL Server临

2010-11-11 09:20:46

SQL Server创
点赞
收藏

51CTO技术栈公众号