制作全局临时表

来源:计算机等级考试    发布时间:2012-08-27    计算机等级考试视频    评论

  我们知道,全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。有时候,你可能想创建一个不属于任何会话的全局临时表。而无论你进行什么操作,它总是存在,只有显式的删除它才能被移除。因此,可以在一个特殊的存储过程中(使用sp_前缀,在master中创建)创建该表并使用“startup”选项标记该存储过程。Sql Server会在每次启动时调用启动过程(startup procedure)。而且,Sql Server为启动过程中创建的全局临时表维护一个大于0的引用计数器,这样就确保Sql Server不会尝试自动删除它。如下所示:
USE master;GOIF OBJECT_ID('dbo.sp_Globals') IS NOT NULLDROP PROC dbo.sp_GlobalGOCREATE proc dbo.sp_GlobalsASCREATE TABLE ##Globals(id varchar(36) NOT NULL PRIMARY KEY,value varchar(500));GOEXEC dbo.sp_procoption 'dbo.sp_Globals','startup','true';

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

  编辑特别推荐:

  ·SQL逻辑查询处理顺序特别提醒

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答