Sqlserver 關於臨時表和表變數的總結
結論
1、一旦建立本地臨時表的會話退出,本地臨時表將被自動刪除;當建立全域性臨時表的會話結束時,並且最後一條引用此表的Transact-SQL語句完成後,全域性臨時表將被自動刪除
2、本地臨時表只對當前會話可見,全域性臨時表的表結構和表裡的資料同時對所有會話可見,其他會話可以查詢和修改全域性臨時表
3、不管本地臨時表還是全域性臨時表,就算指定了資料庫,都是建立建立到了tempdb資料庫下
4、表變數的作用域就是可以引用該變數的 Transact-SQL 語句的範圍。 表變數的作用域從宣告變數的地方開始到宣告變數的批處理或儲存過程的結尾,一個表變數宣告後使用GO再查詢該表變數,則查詢報錯,因為在GO後沒有在再宣告表變數,所以表變數自身沒有鎖的概念,就像oracle的PGA,自己私有的東西沒有共享概念就沒有鎖
實驗1
會話1
use testdb1
CREATE TABLE #localtemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE #localtemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE ##globaltemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE ##globaltemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); insert into #localtemp1 values (1,'1'); insert into #localtemp2 values (1,'1'); insert into ##globaltemp1 values (1,'1'); insert into ##globaltemp2 values (1,'1'); select * from #localtemp1;--有結果 select * from #localtemp2;--有結果 select * from ##globaltemp1;--有結果 select * from ##globaltemp2;--有結果
備註:發現表並不是建立在testdb1庫下面,而是建立在tempdb這個庫下面
會話2
select * from #localtemp1;--報錯,表不存在 select * from #localtemp2;--報錯,表不存在 select * from ##globaltemp1;--有結果 select * from ##globaltemp2;--有結果
會話1退出
會話2
select * from #localtemp1;--報錯,表不存在 select * from #localtemp2;--報錯,表不存在 select * from ##globaltemp1;--報錯,表不存在 select * from ##globaltemp2;--報錯,表不存在
結論:建立本地臨時表的會話一旦退出,本地臨時表自動銷燬了,建立全域性臨時表的會話一旦退出,並且沒有會話引用該全域性臨時表,則該全域性臨時表也自動銷燬了
實驗2
會話1
CREATE TABLE #localtemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE #localtemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE ##globaltemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE ##globaltemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); insert into #localtemp1 values (1,'1'); insert into #localtemp2 values (1,'1'); insert into ##globaltemp1 values (1,'1'); insert into ##globaltemp2 values (1,'1'); select * from #localtemp1;--有結果,1行資料 select * from #localtemp2;--有結果,1行資料 select * from ##globaltemp1;--有結果,1行資料 select * from ##globaltemp2;--有結果,1行資料
會話2
CREATE TABLE ##globaltemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000));--報錯,表已經存在 CREATE TABLE ##globaltemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000));--報錯,表已經存在
會話2
CREATE TABLE #localtemp1(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); CREATE TABLE #localtemp2(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); insert into #localtemp1 values (1,'1'); insert into #localtemp2 values (1,'1'); insert into ##globaltemp1 values (1,'1'); insert into ##globaltemp2 values (1,'1'); select * from #localtemp1;--有結果,1行資料 select * from #localtemp2;--有結果,1行資料 select * from ##globaltemp1;--有結果,2行資料 select * from ##globaltemp2;--有結果,2行資料
結論2:本地臨時表只對當前會話可見,全域性臨時表的表結構和表裡的資料同時對所有會話可見
實驗3
CREATE TABLE testdb1.dbo.#localtemp12(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); Database name 'testdb1' ignored, referencing object in tempdb. CREATE TABLE testdb1.dbo.##localtemp13(Column1 INT NOT NULL,Column2 NVARCHAR(4000)); Database name 'testdb1' ignored, referencing object in tempdb.
結論3:不管本地臨時表還是全域性臨時表,就算指定了資料庫,都是建立建立到了tempdb資料庫下
實驗4.1
DECLARE @LOCALTB1 TABLE( ID INT ,ID2 INT ) DECLARE @@GLOBALTB1 TABLE( ID INT ,ID2 INT ) INSERT INTO @LOCALTB1 SELECT id1,id2 from [dbo].[table1] INSERT INTO @@GLOBALTB1 SELECT id1,id2 from [dbo].[table1] select * from @LOCALTB1 --有結果 select * from @@GLOBALTB1--有結果
實驗4.2
DECLARE @LOCALTB1 TABLE( ID INT ,ID2 INT ) DECLARE @@GLOBALTB1 TABLE( ID INT ,ID2 INT ) INSERT INTO @LOCALTB1 SELECT id1,id2 from [dbo].[table1] INSERT INTO @@GLOBALTB1 SELECT id1,id2 from [dbo].[table1] GO select * from @LOCALTB1 --報錯Must declare the table variable "@LOCALTB1". select * from @@GLOBALTB1 --報錯Must declare the table variable "@@GLOBALTB1".
實驗4.3
DECLARE @LOCALTB1 TABLE( ID INT ,ID2 INT ) DECLARE @@GLOBALTB1 TABLE( ID INT ,ID2 INT ) GO INSERT INTO @LOCALTB1 SELECT id1,id2 from [dbo].[table1] --報錯Must declare the table variable "@LOCALTB1". INSERT INTO @@GLOBALTB1 SELECT id1,id2 from [dbo].[table1] --報錯Must declare the table variable "@@GLOBALTB1". GO select * from @LOCALTB1 --報錯Must declare the table variable "@LOCALTB1". select * from @@GLOBALTB1 --報錯Must declare the table variable "@@GLOBALTB1".
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30126024/viewspace-2748573/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysql關於臨時表的總結MySql
- SQLSERVER 臨時表和表變數到底有什麼區別?SQLServer變數
- SqlServer關於分割槽表的總結SQLServer
- SQLServer臨時表的使用SQLServer
- ORACLE臨時表總結Oracle
- 12C關於CDB、PDB 臨時temp表空間的總結
- Oracle臨時表的用法總結FLOracle
- sqlserver關於filestream檔案流、filetable檔案表的總結SQLServer
- 關於with 臨時表 as的一些用法
- sqlserver關於always on的總結SQLServer
- SQLServer如何釋放tempdb臨時表空間SQLServer
- mysql關於表空間的總結MySql
- 關於SqlServer資料表操作SQLServer
- sqlserver 關於DBCC CHECKDB的總結SQLServer
- sqlserver關於mirror映象的總結SQLServer
- mysql關於memory引擎的表的總結MySql
- sqlserver always on關於備份的總結SQLServer
- oracle臨時表空間相關Oracle
- MySQL臨時表MySql
- PostgreSQL:臨時表SQL
- oracle 臨時表的使用Oracle
- MySQL 中的臨時表MySql
- sqlserver關於日誌傳輸log shipping的總結SQLServer
- Sqlserver關於TDE透明資料加密的使用總結SQLServer加密
- MySQL之臨時表MySql
- mysql 建立臨時表MySql
- Sqlserver關於tempdb臨時資料庫最優檔案個數的最優實踐SQLServer資料庫
- mysql臨時表,臨時表空間,ibtmp1表空間暴增原因初探MySql
- Oracle:優化方法總結(關於連表查詢)Oracle優化
- sqlserver關於釋出訂閱replication_subscription的總結SQLServer
- MySQL 5.7 新特性 共享臨時表空間及臨時表改進MySql
- 變數的分類(臨時(本地)變數、環境變數、全域性變數和系統變數)變數
- Sqlserver表和索引壓縮SQLServer索引
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- mssql sqlserver 快速表備份和表還原的方法SQLServer
- 關於MySQL InnoDB表的二級索引是否加入主鍵的總結MySql索引
- oracle11g 查詢臨時表空間的使用率和正在使用臨時表空間的使用者Oracle
- oracle建立臨時表空間和資料表空間以及刪除Oracle