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
相关推荐
لا معنى له1 小时前
Var-JEPA:联合嵌入预测架构的变分形式 —— 连接预测式与生成式自监督学习 ----论文翻译
人工智能·笔记·学习·语言模型
dyyshb1 小时前
PostgreSQL 终极兜底方案
数据库·postgresql
chase。1 小时前
【学习笔记】让机器人“边想边动”——实时动作分块流策略的执行方法
笔记·学习·机器人
[ ]8982 小时前
Stack_MLAG_知识点梳理
网络·笔记·网络协议
他们叫我技术总监2 小时前
零依赖!FineReport11 快速对接 TDengine 数据库:从驱动部署到报表实现
大数据·数据库·ai·tdengine
TDengine (老段)2 小时前
TDengine IDMP 可视化 —— 定时报告
大数据·数据库·人工智能·物联网·时序数据库·tdengine·涛思数据
曹牧2 小时前
Oracle:
数据库·oracle
kobel282 小时前
Linux x86快速部署openGauss3.1.1指南
数据库
草莓熊Lotso2 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·linux·运维·服务器·数据库·c++·mysql
唐樽2 小时前
C++ 竞赛学习路线笔记
c++·笔记·学习