zoukankan      html  css  js  c++  java
  • sq 如何创建全局的临时表。

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

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

      如下所示:



    Code highlighting produced by Actipro CodeHighlighter (freeware)
    http://www.CodeHighlighter.com/

      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';    //dbo.sp_procoption 只有系统管理员 (sa) 可以将存储过程标记为自动执行。另外,该存储过程必须在 master 数据库中并由 sa 所有,而且不能有输入或输出参数。

     

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

  • 相关阅读:
    SDWebImage 原理及使用问题
    iOS沙盒目录
    java基础知识积累总结
    切片原型[start:stop:step]
    select嵌套问题
    Numpy:字符串转为数值型、日期型;日期型转为数值型
    数据标准化处理(简单整理)
    Numpy:自定义复合数据类型
    Numpy:数组创建 numpy.arrray() , numpy.arange()、np.linspace ()、数组基本属性
    Numpy:使用索引、切片提取一维数组、多维数组内数据
  • 原文地址:https://www.cnblogs.com/sunzhenyong/p/3456484.html
Copyright © 2011-2022 走看看