SQL Server臨時(shí)表的正確刪除方式(sql server 刪除臨時(shí)表)
SQL Server臨時(shí)表的正確刪除方式
臨時(shí)表與一般的表不同,它是保存到tempDb表中。臨時(shí)表的表名與你所建的表名也不一樣,因?yàn)樗獮椴煌说南嗤僮鲃?chuàng)建不同的臨時(shí)表。下文將為您分別示例正確和錯誤的刪除操作,供您參考。
刪除SQL Server臨時(shí)表和一般表并不相同,下面將為您為別示例錯誤和正確的刪除操作,供您參考,希望對您能夠有所幫助。

臨時(shí)表與一般的表不同,它是保存到tempDb表中。臨時(shí)表的表名與你所建的表名也不一樣,因?yàn)樗獮椴煌说南嗤僮鲃?chuàng)建不同的臨時(shí)表。
1、錯誤的刪除操作:
--錯誤的臨時(shí)表刪除操作,因?yàn)樗跀?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 --錯誤的臨時(shí)表刪除操作,因?yàn)榕R時(shí)表名已變 if exists (select * from tempdb.dbo.sysobjects where id = object_id(N'[#temptable]')) Begin drop table #temptable End
2、正確的刪除方式:
--正確的臨時(shí)表刪除操作
if object_id('tempdb..#tempTable') is not null Begin
drop table #tempTable
End補(bǔ)充:SQL臨時(shí)表的使用
關(guān)系型數(shù)據(jù)庫支持臨時(shí)表,這是一項(xiàng)很棒的功能。臨時(shí)表的概念由 SQL Server 引入,用來存儲和處理中間結(jié)果。
臨時(shí)表在會話期間創(chuàng)建,會話結(jié)束后自動被刪除。臨時(shí)表可以和普通表一樣執(zhí)行各種操作,比如 SELECT、UPDATE、INSERT、JOIN 等。
MySQL 3.23 及其更高版本才支持臨時(shí)表,如果您使用的 MySQL 版本低于 3.23,則不能使用臨時(shí)表,但可以使用堆表(Heap Table)。
如前所述,臨時(shí)表僅存在于會話期間。如果您使用 PHP 腳本連接數(shù)據(jù)庫,當(dāng) PHP 執(zhí)行完成后,臨時(shí)表將被銷毀。如果您使用 MySQL 客戶端連接數(shù)據(jù)庫,當(dāng)客戶端關(guān)閉后,臨時(shí)表將被銷毀。
創(chuàng)建臨時(shí)表的基本語法如下:
CREATE TEMPORARY TABLE table_name( column1 datatype, column2 datatype, column3 datatype, ..... columnN datatype, PRIMARY KEY( one or more columns ) );
您看,創(chuàng)建臨時(shí)表的語法和普通表極其相似。臨時(shí)表創(chuàng)建完成以后,可以使用 INSERT、DELETE、UPDATE、SELECT 等命令進(jìn)行增刪改查操作。
示例
本例向您展示臨時(shí)表的用法:
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ù)庫中的表時(shí),臨時(shí)表將不會被顯示。
現(xiàn)在,如果您退出 MySQL 會話,然后使用 SELECT 命令查找數(shù)據(jù),您將在數(shù)據(jù)庫中找不到任何有效數(shù)據(jù),甚至連臨時(shí)表也不存在。
刪除臨時(shí)表
默認(rèn)情況下,當(dāng)數(shù)據(jù)庫連接終止時(shí),MySQL 將刪除所有的臨時(shí)表。但是,如果您希望在會話期間刪除它們,則可以使用 DROP TABLE 命令。
以下是刪除臨時(shí)表的示例:
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臨時(shí)表的正確刪除方式(sql server 刪除臨時(shí)表)的文章就介紹到這了,更多相關(guān)sql刪除臨時(shí)表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
distinct 多列問題結(jié)合group by的解決方法
distinct 多列問題 group by 解決2010-06-06
sqlserver數(shù)據(jù)庫規(guī)模膨脹太大怎么優(yōu)化
數(shù)據(jù)庫規(guī)模膨脹是SQLServer數(shù)據(jù)庫運(yùn)維中常見的問題之一,本文介紹了一些緩解膨脹問題的方法,包括增加內(nèi)存、數(shù)據(jù)壓縮、數(shù)據(jù)庫分區(qū)等,在實(shí)踐過程中,應(yīng)根據(jù)具體情況,采取適當(dāng)?shù)姆椒?以達(dá)到最優(yōu)的緩解膨脹問題的效果2024-02-02
在SQL Server中實(shí)現(xiàn)最短路徑搜索的解決方法
本篇文章小編為大家介紹,在SQL Server中實(shí)現(xiàn)最短路徑搜索的解決方法。需要的朋友參考下2013-04-04
利用sys.sysprocesses檢查SqlServer的阻塞和死鎖
Sys.SysProcesses 系統(tǒng)表是一個很重要的系統(tǒng)視圖,主要用來定位與解決Sql Server的阻塞和死鎖2011-10-10
揭秘SQL Server 2014有哪些新特性(3)-可更新列存儲聚集索引
可更新的列存儲索引作為SQL Server 2014的一個關(guān)鍵功能之一,在提升數(shù)據(jù)庫的查詢性能方面貢獻(xiàn)非常突出。據(jù)微軟統(tǒng)計(jì),在面向OLAP查詢統(tǒng)計(jì)類系統(tǒng)中,相比其他SQL傳統(tǒng)版本的數(shù)據(jù)庫,報(bào)表查詢的性能最大可提升上十倍。2014-08-08
Sql存儲過程游標(biāo)循環(huán)的用法及sql如何使用cursor寫一個簡單的循環(huán)
這篇文章主要介紹了循環(huán)和游標(biāo)在Sql存儲過程中使用及sql如何使用cursor寫一個簡單的循環(huán)的相關(guān)資料,需要的朋友可以參考下2015-11-11

