SQL Server笔记 -- 第70章:临时表的使用

70.1 删除临时表

临时表必须拥有唯一标识(本地临时表在当前会话内唯一,全局临时表在整个实例内唯一)。若再次创建同名临时表,会报错:

已有名为 '#tempTable' 的对象存在于数据库中。

如果脚本会多次运行并创建同名临时表,应在创建前先删除:

sql 复制代码
DROP TABLE #tempTable

首次运行前该表并不存在,直接执行 DROP 会报错:

无法删除表 '#tempTable',因为该表不存在或您没有权限。

因此通常先判断是否存在再删除:

sql 复制代码
IF OBJECT_ID('tempdb..#tempTable','U') IS NOT NULL
  DROP TABLE #tempTable

70.2 本地临时表

  • 仅在当前连接会话期间存在
  • 会话断开时自动删除
  • 表名以单个 # 开头(例如 #temp)
sql 复制代码
CREATE TABLE #LocalTempTable(
  StudentID     int,
  StudentName   varchar(50),
  StudentAddress varchar(150)
)

INSERT INTO #LocalTempTable VALUES (1, '小明', '北京')
SELECT * FROM #LocalTempTable

关闭并重新打开查询窗口后再操作,会报错:

对象名 '#LocalTempTable' 无效。

70.3 全局临时表

  • 表名以 ## 开头
  • 仅当所有引用该表的用户都断开连接时才被删除
  • 行为类似永久表,但生命周期随会话结束而结束
  • 任何数据库用户都可见,不受常规权限限制
sql 复制代码
CREATE TABLE ##NewGlobalTempTable(
  StudentID     int,
  StudentName   varchar(50),
  StudentAddress varchar(150)
)

INSERT INTO ##NewGlobalTempTable VALUES (1, 'Ram', 'India')
SELECT * FROM ##NewGlobalTempTable
相关推荐
_千思_2 小时前
【小白说】数据库系统概念 7
数据库
数据知道2 小时前
JSON 与 BSON 深度解析:理解 MongoDB 底层数据格式与扩展类型。
数据库·mongodb·json
Hy行者勇哥2 小时前
【无标题】
microsoft·学习方法
量子-Alex2 小时前
【强化学习】强化学习的数学原理课程笔记第三章 最优贝尔曼公式
笔记
杨云龙UP2 小时前
Oracle RMAN 归档日志清理标准流程:CROSSCHECK / EXPIRED / SYSDATE-N
运维·服务器·数据库
Highcharts.js2 小时前
Highcharts跨域数据加载完全指南:JSONP原理与实战
javascript·数据库·开发文档·highcharts·图表开发·跨域数据
马猴烧酒.2 小时前
【JAVA算法|hot100】栈类型题目详解笔记
java·笔记
知识分享小能手2 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 安全机制 — 语法知识点及使用方法详解(18)
数据库·学习·sqlserver
Rsingstarzengjx2 小时前
【Photoshop从入门到精通】-21 图层进阶 笔记
笔记·ui·photoshop