首頁 > 軟體

SQL Server臨時表的正確刪除方式(sql server 刪除臨時表)

2023-09-07 10:00:03

SQL Server臨時表的正確刪除方式

臨時表與一般的表不同,它是儲存到tempDb表中。臨時表的表名與你所建的表名也不一樣,因為他要為不同人的相同操作建立不同的臨時表。下文將為您分別範例正確和錯誤的刪除操作,供您參考。

刪除SQL Server臨時表和一般表並不相同,下面將為您為別範例錯誤和正確的刪除操作,供您參考,希望對您能夠有所幫助。

臨時表與一般的表不同,它是儲存到tempDb表中。臨時表的表名與你所建的表名也不一樣,因為他要為不同人的相同操作建立不同的臨時表。

1、錯誤的刪除操作:

--錯誤的臨時表刪除操作,因為所在資料庫不同
IF EXISTS (SELECT * FROM sysobjects WHERE object_id = OBJECT_ID(N'[dbo].[#tempTable]') AND type in (N'U'))
Begin
DROP TABLE [dbo].[tempTable]
End
--錯誤的臨時表刪除操作,因為臨時表名已變
if exists (select * from tempdb.dbo.sysobjects where id = object_id(N'[#temptable]'))
Begin
drop table #temptable
End

2、正確的刪除方式:

--正確的臨時表刪除操作
if object_id('tempdb..#tempTable') is not null Begin
drop table #tempTable
End

補充:SQL臨時表的使用

關係型資料庫支援臨時表,這是一項很棒的功能。臨時表的概念由 SQL Server 引入,用來儲存和處理中間結果。

臨時表在對談期間建立,對談結束後自動被刪除。臨時表可以和普通表一樣執行各種操作,比如 SELECT、UPDATE、INSERT、JOIN 等。

MySQL 3.23 及其更高版本才支援臨時表,如果您使用的 MySQL 版本低於 3.23,則不能使用臨時表,但可以使用堆表(Heap Table)。

如前所述,臨時表僅存在於對談期間。如果您使用 PHP 指令碼連線資料庫,當 PHP 執行完成後,臨時表將被銷燬。如果您使用 MySQL 使用者端連線資料庫,當用戶端關閉後,臨時表將被銷燬。

建立臨時表的基本語法如下:

CREATE TEMPORARY TABLE table_name(
   column1 datatype,
   column2 datatype,
   column3 datatype,
   .....
   columnN datatype,
   PRIMARY KEY( one or more columns )
);

您看,建立臨時表的語法和普通表極其相似。臨時表建立完成以後,可以使用 INSERT、DELETE、UPDATE、SELECT 等命令進行增刪改查操作。

範例

本例向您展示臨時表的用法:

mysql> CREATE TEMPORARY TABLE SALESSUMMARY (
   -> product_name VARCHAR(50) NOT NULL
   -> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
   -> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
   -> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO SALESSUMMARY
   -> (product_name, total_sales, avg_unit_price, total_units_sold)
   -> VALUES
   -> ('cucumber', 100.25, 90, 2);

mysql> SELECT * FROM SALESSUMMARY;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber     |      100.25 |          90.00 |                2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)

當您使用 SHOW TABLES 命令檢視資料庫中的表時,臨時表將不會被顯示。

現在,如果您退出 MySQL 對談,然後使用 SELECT 命令查詢資料,您將在資料庫中找不到任何有效資料,甚至連臨時表也不存在。

刪除臨時表

預設情況下,當資料庫連線終止時,MySQL 將刪除所有的臨時表。但是,如果您希望在對談期間刪除它們,則可以使用 DROP TABLE 命令。

以下是刪除臨時表的範例:

mysql> CREATE TEMPORARY TABLE SALESSUMMARY (
   -> product_name VARCHAR(50) NOT NULL
   -> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
   -> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
   -> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO SALESSUMMARY
   -> (product_name, total_sales, avg_unit_price, total_units_sold)
   -> VALUES
   -> ('cucumber', 100.25, 90, 2);

mysql> SELECT * FROM SALESSUMMARY;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber     |      100.25 |          90.00 |                2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
mysql> DROP TABLE SALESSUMMARY;
mysql>  SELECT * FROM SALESSUMMARY;
ERROR 1146: Table 'TUTORIALS.SALESSUMMARY' doesn't exist

到此這篇關於SQL Server臨時表的正確刪除方式(sql server 刪除臨時表)的文章就介紹到這了,更多相關sql刪除臨時表內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com