sqlserver基本介紹,sqlserver臨時表操作

 2023-10-18 阅读 21 评论 0

摘要:創建臨時表 ?????? 方法一: ???? create table #臨時表名(字段1 約束條件, ??????????????????????字段2 約束條件, ??????????????????.....) ????????create table ##臨時表名(字段1 約束條件, ??????????????????????????字段2 約束條件, ??????????????????????..

創建臨時表
?????? 方法一:
???? create table #臨時表名(字段1 約束條件,
??????????????????????字段2 約束條件,
??????????????????.....)
????????create table ##臨時表名(字段1 約束條件,
??????????????????????????字段2 約束條件,
??????????????????????.....)
????????方法二:
???? select * into #臨時表名 from 你的表;
?????? select * into ##臨時表名 from 你的表;
注:以上的#代表局部臨時表,##代表全局臨時表

查詢臨時表
???? select * from #臨時表名;
?????? select * from ##臨時表名;

刪除臨時表
???? drop table #臨時表名;
?????? drop table ##臨時表名;

?

sqlserver基本介紹、?

?

SQL SERVER臨時表的使用
http://www.cnblogs.com/shineqiujuan/archive/2008/11/13/1332657.html

?

sql 臨時表?drop table #Tmp?? --刪除臨時表#Tmp
create table #Tmp --創建臨時表#Tmp
(
??? ID?? int IDENTITY (1,1)???? not null, --創建列ID,并且每次新增一條記錄就會加1
??? WokNo??????????????? varchar(50),??
??? primary key (ID)????? --定義ID為臨時表#Tmp的主鍵?????
);
Select * from #Tmp??? --查詢臨時表的數據
truncate table #Tmp --清空臨時表的所有數據和約束

相關例子:

Declare @Wokno Varchar(500) --用來記錄職工號
Declare @Str NVarchar(4000) --用來存放查詢語句
Declare @Count int --求出總記錄數?????
Declare @i int
Set @i = 0
Select @Count = Count(Distinct(Wokno)) from #Tmp
While @i < @Count
??? Begin
?????? Set @Str = 'Select top 1 @Wokno = WokNo from #Tmp Where id not in (Select top ' + Str(@i) + 'id from #Tmp)'
?????? Exec Sp_ExecuteSql @Str,N'@WokNo Varchar(500) OutPut',@WokNo Output
?????? Select @WokNo,@i --一行一行把職工號顯示出來
?????? Set @i = @i + 1
??? End

sqlserver創建視圖。
臨時表
可以創建本地和全局臨時表。本地臨時表僅在當前會話中可見;全局臨時表在所有會話中都可見。
本地臨時表的名稱前面有一個編號符 (#table_name),而全局臨時表的名稱前面有兩個編號符 (##table_name)

SQL 語句使用 CREATE TABLE 語句中為 table_name 指定的名稱引用臨時表:

CREATE TABLE #MyTempTable (cola INT PRIMARY KEY)
INSERT INTO #MyTempTable VALUES (1)

sql server2012使用、如果本地臨時表由存儲過程創建或由多個用戶同時執行的應用程序創建,則 SQL Server 必須能夠區分由不同用戶創建的表。為此,SQL Server 在內部為每個本地臨時表的表名追加一個數字后綴。存儲在 tempdb 數據庫的 sysobjects 表中的臨時表,其全名由 CREATE TABLE 語句中指定的表名和系統生成的數字后綴組成。為了允許追加后綴,為本地臨時表指定的表名 table_name 不能超過 116 個字符。

除非使用 DROP TABLE 語句顯式除去臨時表,否則臨時表將在退出其作用域時由系統自動除去:

當存儲過程完成時,將自動除去在存儲過程中創建的本地臨時表。由創建表的存儲過程執行的所有嵌套存儲過程都可以引用此表。但調用創建此表的存儲過程的進程無法引用此表。

sql server有什么用?
所有其它本地臨時表在當前會話結束時自動除去。


全局臨時表在創建此表的會話結束且其它任務停止對其引用時自動除去。任務與表之間的關聯只在單個 Transact-SQL 語句的生存周期內保持。換言之,當創建全局臨時表的會話結束時,最后一條引用此表的 Transact-SQL 語句完成后,將自動除去此表。
在存儲過程或觸發器中創建的本地臨時表與在調用存儲過程或觸發器之前創建的同名臨時表不同。如果查詢引用臨時表,而同時有兩個同名的臨時表,則不定義針對哪個表解析該查詢。嵌套存儲過程同樣可以創建與調用它的存儲過程所創建的臨時表同名的臨時表。嵌套存儲過程中對表名的所有引用都被解釋為是針對該嵌套過程所創建的表,例如:

CREATE PROCEDURE Test2
AS
CREATE TABLE #t(x INT PRIMARY KEY)
INSERT INTO #t VALUES (2)
SELECT Test2Col = x FROM #t
GO
CREATE PROCEDURE Test1
AS
CREATE TABLE #t(x INT PRIMARY KEY)
INSERT INTO #t VALUES (1)
SELECT Test1Col = x FROM #t
EXEC Test2
GO
CREATE TABLE #t(x INT PRIMARY KEY)
INSERT INTO #t VALUES (99)
GO
EXEC Test1
GO

sqlserver數據庫。下面是結果集:

(1 row(s) affected)

Test1Col???
-----------
1??????????

(1 row(s) affected)

Test2Col???
-----------
2??????????

當創建本地或全局臨時表時,CREATE TABLE 語法支持除 FOREIGN KEY 約束以外的其它所有約束定義。如果在臨時表中指定 FOREIGN KEY 約束,該語句將返回警告信息,指出此約束已被忽略,表仍會創建,但不具有 FOREIGN KEY 約束。在 FOREIGN KEY 約束中不能引用臨時表。

考慮使用表變量而不使用臨時表。當需要在臨時表上顯式地創建索引時,或多個存儲過程或函數需要使用表值時,臨時表很有用。通常,表變量提供更有效的查詢處理。

?

轉載于:https://www.cnblogs.com/fumj/p/3516870.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/2/147748.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息