mysql存儲過程好處
可以,存儲過程只是把你的查詢語句形成一個固定的格式,這樣你要查詢的時候就不用每次都執行查詢語句了,sql在執行的時候都會將你的sql語句轉換為位元組碼,然後機器才能運行,存儲過程就節省了這一步,已經形成了位元組碼,所以速度才會快,特別是執行次數比較多的時候,可以節省很多時間
B. mysql中的存儲過程是什麼意思啊
直白的講就是把SQL語句進行封裝,然後留個介面,使用的時候直接調用介面。
C. mysql存儲過程 和 觸發器的優缺點 問題
缺點是觸發器的缺點,
而有點是存儲過程的優點,
所以推薦使用存儲過程。
D. mysql 存儲過程 是什麼意思
用select...into語句
下面是mysql 5.0的幫助文檔的:
這個SELECT語法把選定的列直接存儲到變數。因此,只有單一的行可以被取回。
SELECT id,data INTO x,y FROM test.t1 LIMIT 1;
注意,用戶變數名在MySQL 5.1中是對大小寫不敏感的。請參閱9.3節,「用戶變數」。
重要: SQL變數名不能和列名一樣。如果SELECT ... INTO這樣的SQL語句包含一個對列的參考,並包含一個與列相同名字的局部變數,MySQL當前把參考解釋為一個變數的名字。例如,在下面的語句中,xname 被解釋為到xname variable 的參考而不是到xname column的:
CREATE PROCEDURE sp1 (x VARCHAR(5))
BEGIN
DECLARE xname VARCHAR(5) DEFAULT 'bob';
DECLARE newname VARCHAR(5);
DECLARE xid INT;
SELECT xname,id INTO newname,xid
FROM table1 WHERE xname = xname;
SELECT newname;
END;
當這個程序被調用的時候,無論table.xname列的值是什麼,變數newname將返回值『bob』。
E. 為什麼要使用存儲過程
存儲過程是指一組具有某種特殊功能的SQL語句集,常用於大型資料庫中,也出現於開發過程中。程序員經常運用存儲過程是由於其具有以下優點:
一、響應時間上來說有優勢:如果你在前台處理的話。可能會涉及到多次資料庫連接。但如果你用存儲過程的話,就只有一次。存儲過程可以給我們帶來運行效率提高的好處。
二、安全上使用了存儲過程的系統更加穩定:程序容易出現 BUG 不穩定,而存儲過程,只要資料庫不出現問題,基本上是不會出現什麼問題的。
(5)mysql存儲過程好處擴展閱讀
存儲過程不僅僅適用於大型項目,對於中小型項目,使用存儲過程也是非常有必要的。
一般來說,存儲過程的編寫比基本SQL語句復雜,編寫存儲過程需要更高的技能,更豐富的經驗。經自已測試,一個有著十萬條記錄的表,通過php調用存儲過程比通過PHP執行sql語句獲取所有記錄的時間,平均快0.4秒左右。
F. mysql中使用存儲過程進行查詢效率高嗎
mysql中使用存儲過程進行查詢效率高嗎
能,存儲過程是在伺服器端運行的。 1、執行速度比普通的SQL語句快 再運行存儲過程前,資料庫已對其進行了語法和句法分析,並給出了優化執行方案。這種已經編譯好的過程可極大地改善SQL語句的性能。
G. mysql存儲過程是什麼意思什麼時候會用到,主要用來做什麼
mysql 執行語句是要先編譯,然後再執行的。這樣如果查詢並發大的時候。會浪費很多資源和時間。造成mysql進程佔用資源過多,症狀就是慢。
但存儲過程可以把一些特別的語句封裝成一個方法 ,再編譯好成一個可以執行的方法,對外只要接收參數就可以了。這樣就不用再編譯。執行就快了
什麼時候會用到?你覺得你資料庫因為同時出現太多讀寫操作而變得慢 ,那麼就要用了
主要用來提升性能。。
H. mysql 存儲過程
.關於MySQL的存儲過程
存儲過程是資料庫存儲的一個重要的功能,但是MySQL在5.0以前並不支持存儲過程,這使得MySQL在應用上大打折扣。好在MySQL 5.0終於開始已經支持存儲過程,這樣即可以大大提高資料庫的處理速度,同時也可以提高資料庫編程的靈活性。
MySQL存儲過程的創建
(1).格式
MySQL存儲過程創建的格式:CREATE PROCEDURE過程名([過程參數[,...]])
[特性...]過程體
這里先舉個例子:
mysql>DELIMITER//
mysql>CREATEPROCEDUREproc1(OUTsint)
->BEGIN
->SELECTCOUNT(*)INTOsFROMuser;
->END
->//
mysql>DELIMITER;
- 註:
(1)這里需要注意的是DELIMITER //和DELIMITER ;兩句,DELIMITER是分割符的意思,因為MySQL默認以";"為分隔符,如果我們沒有聲明分割符,那麼編譯器會把存儲過程當成SQL語句進行處理,則存儲過程的編譯過程會報錯,所以要事先用DELIMITER關鍵字申明當前段分隔符,這樣MySQL才會將";"當做存儲過程中的代碼,不會執行這些代碼,用完了之後要把分隔符還原。
(2)存儲過程根據需要可能會有輸入、輸出、輸入輸出參數,這里有一個輸出參數s,類型是int型,如果有多個參數用","分割開。
(3)過程體的開始與結束使用BEGIN與END進行標識。
I. mysql 存儲過程和函數的區別
mysql 存儲過程和函數的區別
1、
存儲過程實現的功能要復雜一點,函數實現的功能針對性比較強。
存儲過程,功能強大,可以執行包括修改表等一系列資料庫操作;
用戶定義函數不能用於執行一組修改全局資料庫狀態的操作。
2、
對於存儲過程來說可以返回參數,如記錄集,函數只能返回值或者表對象。
函數只能返回一個變數;而存儲過程可以返回多個;
存儲過程的參數可以有IN,OUT,INOUT三種類型,而函數只能有IN類;
存儲過程聲明時不需要返回類型,而函數聲明時需要描述返回類型,且函數體中必須包含一個有效的RETURN語句。
3、
存儲過程,可以使用非確定函數,不允許在用戶定義函數主體中內置非確定函數。
4、
存儲過程一般是作為一個獨立的部分來執行( EXECUTE 語句執行),而函數可以作為查詢語句的一個部分來調用(SELECT調用)。
由於函數可以返回一個表對象,因此它可以在查詢語句中位於FROM關鍵字的後面。 SQL語句中不可用存儲過程,而可以使用函數。