我正在运行这样一条SELECT INTO语句,这样我就可以在最终删除表之前操作数据。
SELECT colA, colB, colC INTO #preop FROM tblRANDOM但是,当我运行该语句,然后,在没有删除新创建的表的情况下,我运行了以下任一语句,却没有找到该表?即使浏览对象资源管理器,我也看不到它。我应该往哪里看呢?
SELECT [name] FROM sysobjects WHERE [name] = N'#preop'
SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '#preop'发布于 2014-02-06 00:50:28
临时表不存储在本地数据库中,它们存储在tempdb中。此外,它们的名称也不是您命名的名称;它有一个十六进制代码后缀和一堆下划线,以消除会话之间的歧义。您应该使用sys.objects或sys.tables,而不是deprecated sysobjects (note the big warning at the top)或the incomplete and stale INFORMATION_SCHEMA views。
SELECT name FROM tempdb.sys.objects WHERE name LIKE N'#preop[_]%';如果您正在尝试确定会话中是否存在此类对象,以便您知道是否应首先删除它,则应执行以下操作:
IF OBJECT_ID('tempdb.dbo.#preop') IS NOT NULL
BEGIN
DROP TABLE #preop;
END在现代版本(SQL Server 2016+)中,这甚至更容易:
DROP TABLE IF EXISTS #preop;但是,如果这段代码在存储过程中,那么就没有必要这么做了……当存储过程超出作用域时,应该自动删除该表。
发布于 2019-06-11 23:49:49
下面是我如何获得临时表的列的:
CREATE TABLE #T (PK INT IDENTITY(1,1), APP_KEY INT PRIMARY KEY)
SELECT * FROM tempdb.INFORMATION_SCHEMA.COLUMNS c WHERE c.TABLE_NAME LIKE '#T%'发布于 2016-05-25 19:53:53
我更喜欢用这样的方式查询tempdb:
IF EXISTS (SELECT * FROM tempdb.sys.objects
WHERE object_id = OBJECT_ID(N'tempdb.[dbo].[#MyProcedure]')
AND type in (N'P', N'PC'))
BEGIN
print 'dropping [dbo].[#MyProcedure]'
DROP PROCEDURE [dbo].[#MyProcedure]
END
GOhttps://stackoverflow.com/questions/21583268
复制相似问题