⑴ 關於sql的臨時表、自定義函數、儲存過程的問題
如果你有編程基礎的話那麼自定義函數和存儲過程的區別,就是程序裡面函數與過程的區別,函數只是為了實現某個功能,而過程是為了實現某個流程。至於使用的時間 這個跟你的實際需求有關系的,一般系統帶的函數就能滿足需求。存儲過程這個看你項目的訪問量,訪問量小的話 如果是快速開發不會用到存儲過程 直接在程序裡面寫SQL語句就OK。如果訪問量大,那麼必須使用存儲過程。 臨時表的好處是它可以是只對某個用戶的表,而且不具有實際意義,並且可以定義自動銷毀的臨時表。跟視圖在某種情況下有相同之處。臨時表的試用時間也是跟你的需求有關系的。創建語句差不多 都是T-SQL語句。 最後一個問題你得搜索一下才知道,一般情況下定義的臨時表都是自動銷毀的,使用完畢會drop掉(節省資源,如果是#開頭的臨時表 系統會自動在使用完畢後銷毀掉。)
⑵ SQL Server里的臨時表放在那裡
臨時表與永久表相似,但臨時表存儲在 tempdb 中,當不再使用時會自動刪除。
臨時表有兩種類型:本地和全局。它們在名稱、可見性以及可用性上有區別。本地臨時表的名稱以單個數字元號 (#) 打頭;它們僅對當前的用戶連接是可見的;當用戶從 SQL Server 實例斷開連接時被刪除。全局臨時表的名稱以兩個數字元號 (##) 打頭,創建後對任何用戶都是可見的,當所有引用該表的用戶從 SQL Server 斷開連接時被刪除。
例如,如果創建了 employees 表,則任何在資料庫中有使用該表的安全許可權的用戶都可以使用該表,除非已將其刪除。如果資料庫會話創建了本地臨時表 #employees,則僅會話可以使用該表,會話斷開連接後就將該表刪除。如果創建了 ##employees 全局臨時表,則資料庫中的任何用戶均可使用該表。如果該表在您創建後沒有其他用戶使用,則當您斷開連接時該表刪除。如果您創建該表後另一個用戶在使用該表,則 SQL Server 將在您斷開連接並且所有其他會話不再使用該表時將其刪除。
⑶ sql 怎樣將其它表中數據的統計結果存入臨時表
用select * into newtemptable from yourtable
有些資料庫有專業的臨時表,關閉就消失的那種,不知道是不是你要的。
用前綴_,或__代表臨時表。
那就計算,統計不也是select嗎,在適當的位置加上into就好了,具體的語法根據資料庫的不同略有區別
要分清楚,計算、存放、臨時表是三個不同的概念
1.你能把需要的統計結果得出來嗎,比如用select語句在調試工具中看得到你需要的結果嗎
2.簡單的保存在適當的地方into就行了,
3.你需要的臨時表是資料庫概念中的臨時表嗎,如果是請查你用的資料庫幫助中關於臨時表的試用,如果「臨時」只是對你來說的,請用完後自己drop掉table
⑷ SQL 怎樣把查詢的結果保存成一張臨時表
假如你的多表查詢是 select * from 表 where 條件
那麼你要的語句就是
select * into #temp from 表 where 條件
這里很簡單就可以完成 在你的查詢出來的列名 和from之間 這里是select *和from 你的可能不是
添加 into #你的臨時表名 其他都不做改動
⑸ 如何將臨時表中的數據保存到資料庫...
引用
8
樓
的回復:能不能說清楚啊,我都糊塗了。。insert
into
table
這個表是臨時表啊,還是實際表啊。values(參數值)
臨時表裡有好多條記錄啊,,該怎麼寫啊。
⑹ SQL腳本中循環內的臨時表保存問題
如果你能保證有極少用戶調用這個存儲過程,可以考慮用全局表變數##P
或者可以給調用者一個傳入表的隨機參數,以達到不重復的目的
⑺ SQL存儲過程中如何插入使用臨時表
在存儲過程中 是不可以創建臨時表的...
建議使用表變數代替臨時表進行操作 或者在存儲過程外面建好臨時表
祝你好運
⑻ Sql中的創建的臨時表存在哪裡,能存多久
一般存在你建表的那個資料庫里,只要程序退出,就會被系統自動刪除
⑼ SQL臨時表使用
1、創建方法:
方法一:
create table TempTableName
或
select [欄位1,欄位2,...,] into TempTableName from table
方法二:
create table tempdb.MyTempTable(Tid int)
說明:
(1)、臨時表其實是放在資料庫tempdb里的一個用戶表;
(2)、TempTableName必須帶「#」,「#"可以是一個或者兩個,以#(局部)或##(全局)開頭的表,這種表在會話期間存在,會話結束則自動刪除;
(3)、如果創建時不以#或##開頭,而用tempdb.TempTable來命名它,則該表可在資料庫重啟前一直存在。
2、手動刪除
drop table TempTableName
說明:
DROP TABLE 語句顯式除去臨時表,否則臨時表將在退出其作用域時由系統自動除去:
(1)、當存儲過程完成時,將自動除去在存儲過程中創建的本地臨時表。由創建表的存儲過程執行的所有嵌套存儲過程都可以引用此表。但調用創建此表的存儲過程的進程無法引用此表;
(2)、所有其它本地臨時表在當前會話結束時自動除去;
(3)、全局臨時表在創建此表的會話結束且其它任務停止對其引用時自動除去。任務與表之間的關聯只在單個Transact-SQL語句的生存周期內保持。換言之,當創建全局臨時表的會話結束時,最後一條引用此表的Transact-SQL語句完成後,將自動除去此表。
⑽ sql 函數中怎麼保存臨時數據
你說的意思是什麼,如果你想長時間保存數據就不要用臨時表,如果你想在sql語句結束之後數據存儲的就消失,這時候你才考慮用臨時表。臨時表的作用就是節省資料庫資源,具體你的目的是什麼,說清楚點才知道你想要做什麼!