本質上沒區別。只是函數有如:只能返回一個變數的限制。而存儲過程可以返回多個。而函數是可以嵌入在sql中使用的,可以在select中調用,而存儲過程不行。執行的本質都一樣。
函數限制比較多,比如不能用臨時表,只能用表變數.還有一些函數都不可用等等.而存儲過程的限制相對就比較少
1. 一般來說,存儲過程實現的功能要復雜一點,而函數的實現的功能針對性比較強。
2. 對於存儲過程來說可以返回參數,而函數只能返回值或者表對象。
3. 存儲過程一般是作為一個獨立的部分來執行(EXEC執行),而函數可以作為查詢語句的一個部分來調用(SELECT調用),由於函數可以返回一個表對象,因此它可以在查詢語句中位於FROM關鍵字的後面。
4. 當存儲過程和函數被執行的時候,SQL Manager會到procere cache中去取相應的查詢語句,如果在procere cache里沒有相應的查詢語句,SQL Manager就會對存儲過程和函數進行編譯。
Procere cache中保存的是執行計劃 (execution plan) ,當編譯好之後就執行procere cache中的execution plan,之後SQL SERVER會根據每個execution plan的實際情況來考慮是否要在cache中保存這個plan,評判的標准一個是這個execution plan可能被使用的頻率;其次是生成這個plan的代價,也就是編譯的耗時。保存在cache中的plan在下次執行時就不用再編譯了。
❷ 函數和存儲過程區別
首先糾正一個錯誤,存儲過程也有參數和返回值的 例如 exec @Ret = p_Proc @a
最直白的說 可以在select 中使用函數 而過程只能用exec 執行
❸ 存儲過程和函數的區別
存儲過程是用戶定義的一系列sql語句的集合,涉及特定表或其它對象的任務,用戶可以調用存儲過程,而函數通常是資料庫已定義的方法,它接收參數並返回某種類型的值並且不涉及特定用戶表。
❹ 存儲過程中=和:=有什麼區別
oracle 判斷語句 if a=b then end if
賦值 a:=1
sqlserver 判斷語句 if a=b
賦值 set a=1
❺ oracle 存儲過程中的 := 和=有什麼區別
:= 是賦值符號,例如: a := 2, 那麼變數a的值,就是2了
= 是比較符號, 例如: ... WHERE 欄位名 = 2,和 > < 是一樣的性質
❻ 什麼是存儲過程
sql語句執行的時候要先編譯,然後執行。存儲過程就是編譯好了的一些sql語句。用的時候直接就可以用了。所以效率會高 一 存儲過程介紹 存儲過程是由流控制和SQL語句書寫的過程,這個過程經編譯和優化 後存儲在資料庫伺服器中,使用時只要調用即可。在ORACLE中,若干個 有聯系的過程可以組合在一起構成程序包。 使用存儲過程有以下的優點: * 存儲過程的能力大大增強了SQL語言的功能和靈活性。存儲過程可 以用流控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的 運算。 * 可保證數據的安全性和完整性。 # 通過存儲過程可以使沒有許可權的用戶在控制之下間接地存取數據 庫,從而保證數據的安全。 # 通過存儲過程可以使相關的動作在一起發生,從而可以維護數據 庫的完整性。 * 再運行存儲過程前,資料庫已對其進行了語法和句法分析,並給出 了優化執行方案。這種已經編譯好的過程可極大地改善SQL語句的性能。 由於執行SQL語句的大部分工作已經完成,所以存儲過程能以極快的速度執 行。 * 可以降低網路的通信量。 * 使體現企業規則的運算程序放入資料庫伺服器中,以便: # 集中控制。 # 當企業規則發生變化時在伺服器中改變存儲過程即可,無須修改 任何應用程序。企業規則的特點是要經常變化,如果把體現企業規則的運 算程序放入應用程序中,則當企業規則發生變化時,就需要修改應用程序 工作量非常之大(修改、發行和安裝應用程序)。如果把體現企業規則的 運算放入存儲過程中,則當企業規則發生變化時,只要修改存儲過程就可 以了,應用程序無須任何變化。 不同資料庫存儲過程的寫法不一,在後面的講座中將分別介紹ORACLE 和SYBASE存儲過程的用法。 二 ORACLE 的存儲過程 ORACLE 創建存儲過程的語法為: create [or replace] procere 過程名 參數1 [in|out|in out] 數據類型 [,參數2 [in|out|in out] 數據類型]... pl/sql 語句 下面舉例說明ORACLE資料庫存儲過程的寫法和用法。 可以建立一個存儲過程,每當用戶修改資料庫的重要數據時,即把 用戶的用戶名、掌諍筒僮骼嘈圖鍬枷呂矗?nbsp; create procere update_log is begin insert into update_log_tab(use_name,update_date,operation) values(user,sysdate,'update' end; 可以在恰當的位置調用這個存儲過程來記錄用戶對表的修改。例如下面在 表sal_comm上建立一個修改觸發器,每當用戶修改此表後,用戶的名稱、修改 時間和操作即被記錄在了表update_log_tab中: create trigger audit_update after update on sal_comm for each row begin update_log end --三 Sybase的存儲過程 盡管Sybase存儲過程的功能和寫法與ORACLE類似,但他們之間還是 有一定的差別。下面講述SYBASE的存儲過程。 SYBASE可以用CREATE PROCere命令生成存儲過程: CREATE PROCere 存儲過程名 [;number] [[(] @parameter_name datatype [=default] [OUTput] [, @parameter_name datatype [=default] [OUTput]]...[)]] [WITH RECOMPILE] AS SQL_statements 下面是一個查詢作者編碼、名稱和生日的存儲過程: create proc p_auths @author_code varchar(10) as select author_code, name, birthdate from auths where author_code=@author_code 下面執行過程p_auths: p_auths @author_code=A00001 在CREATE PROC語句中,可以為參數賦預設值,該值可以是任何常量。 當用戶不提供參數值時,該值便作為參數值提供給過程。
❼ 函數和存儲過程的區別
從參數的返回情況來看
如果返回多個參數值最好使用存儲過程,如果只有一個返回值的話可以使用函數;
從調用情況來看
如果在SQL語句(DML或SELECT)中調用的話一定是存儲函數或存儲的封裝函數不可以是存儲過程
❽ 存儲過程和sql語句有什麼區別
1、sql只能實現簡單的查詢,新增,修改,刪除功能。
2、存儲過程是sql語句和可選控制流語句的預編譯集合。存儲過程在創建時即在伺服器上進行編譯,所以執行起來比單個sql語句快。在單個存儲過程中可以執行一系列sql語句。可以從自己的存儲過程內引用其他存儲過程。
❾ 存儲過程和函數的區別是什麼
存儲過程需要單獨執行;
函數可以隨處調用。
存儲過程是保存起來的可以接受和返回用戶提供的參數的 Transact-SQL 語句的集合。
可以創建一個過程供永久使用,或在一個會話中臨時使用(局部臨時過程),或在所有會話中臨時使用(全局臨時過程)。
也可以創建在 Microsoft® SQL Server™ 啟動時自動運行的存儲過程。
用戶定義函數,它是返回值的已保存的 Transact-SQL 常式。用戶定義函數不能用於執行一組修改全局資料庫狀態的操作。
與系統函數一樣,用戶定義函數可以從查詢中喚醒調用。也可以像存儲過程一樣,通過 EXECUTE 語句執行。
http://topic.csdn.net/t/20030806/16/2116067.html
http://www.cnsdn.com.cn/blog/article.asp?id=2035這個的解釋也很好。