SQL Server臨時表的正確刪除方式(sql server 刪除臨時表)
SQL Server臨時表的正確刪除方式
臨時表與一般的表不同,它是保存到tempDb表中。臨時表的表名與你所建的表名也不一樣,因為他要為不同人的相同操作創(chuàng)建不同的臨時表。下文將為您分別示例正確和錯誤的刪除操作,供您參考。
刪除SQL Server臨時表和一般表并不相同,下面將為您為別示例錯誤和正確的刪除操作,供您參考,希望對您能夠有所幫助。
臨時表與一般的表不同,它是保存到tempDb表中。臨時表的表名與你所建的表名也不一樣,因為他要為不同人的相同操作創(chuàng)建不同的臨時表。
1、錯誤的刪除操作:
--錯誤的臨時表刪除操作,因為所在數(shù)據(jù)庫不同 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臨時表的使用
關(guān)系型數(shù)據(jù)庫支持臨時表,這是一項很棒的功能。臨時表的概念由 SQL Server 引入,用來存儲和處理中間結(jié)果。
臨時表在會話期間創(chuàng)建,會話結(jié)束后自動被刪除。臨時表可以和普通表一樣執(zhí)行各種操作,比如 SELECT、UPDATE、INSERT、JOIN 等。
MySQL 3.23 及其更高版本才支持臨時表,如果您使用的 MySQL 版本低于 3.23,則不能使用臨時表,但可以使用堆表(Heap Table)。
如前所述,臨時表僅存在于會話期間。如果您使用 PHP 腳本連接數(shù)據(jù)庫,當(dāng) PHP 執(zhí)行完成后,臨時表將被銷毀。如果您使用 MySQL 客戶端連接數(shù)據(jù)庫,當(dāng)客戶端關(guān)閉后,臨時表將被銷毀。
創(chuàng)建臨時表的基本語法如下:
CREATE TEMPORARY TABLE table_name( column1 datatype, column2 datatype, column3 datatype, ..... columnN datatype, PRIMARY KEY( one or more columns ) );
您看,創(chuàng)建臨時表的語法和普通表極其相似。臨時表創(chuàng)建完成以后,可以使用 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)
當(dāng)您使用 SHOW TABLES 命令查看數(shù)據(jù)庫中的表時,臨時表將不會被顯示。
現(xiàn)在,如果您退出 MySQL 會話,然后使用 SELECT 命令查找數(shù)據(jù),您將在數(shù)據(jù)庫中找不到任何有效數(shù)據(jù),甚至連臨時表也不存在。
刪除臨時表
默認情況下,當(dāng)數(shù)據(jù)庫連接終止時,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
到此這篇關(guān)于SQL Server臨時表的正確刪除方式(sql server 刪除臨時表)的文章就介紹到這了,更多相關(guān)sql刪除臨時表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL?Server誤區(qū)30日談?第24天?26個有關(guān)還原(Restore)的誤區(qū)
本系列文章一直所沒有觸及的就是有關(guān)”還原(Restore)”的話題,因為一旦牽扯到這個話題就會涉及大量的誤區(qū),多到我無法通過一篇文章說完的地步。<BR>2013-01-01win2008 r2 安裝sql server 2005/2008 無法連接服務(wù)器解決方法
在與 SQL Server 建立連接時出現(xiàn)與網(wǎng)絡(luò)相關(guān)的或特定于實例的錯誤。未找到或無法訪問服務(wù)器。請驗證實例名稱是否正確并且 SQL Server 已配置為允許遠程連接2015-01-01sql server 2012 數(shù)據(jù)庫所有表里查找某字符串的方法
此TSQL語句是針對SQL Server 2012編寫。如果使用之前版本,需要對部分語句進行重寫。2013-03-03SQL?Server中元數(shù)據(jù)函數(shù)的用法
這篇文章介紹了SQL?Server中元數(shù)據(jù)函數(shù)的用法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05