tft每日頭條

 > 生活

 > mysql的存儲過程和引擎

mysql的存儲過程和引擎

生活 更新时间:2025-01-07 10:45:15
第一》怎麼是Mysql存儲過程?

存儲過程是一組為了完成特定功能的 SQL 語句集合。MySQL 5.0 終于開始已經支持存儲過程,它是數據庫中最重要的功能,

1.使用存儲過程的目的:将常用或複雜的工作預先用 SQL 語句寫好并用一個指定名稱存儲起來,這個過程經編譯和優化後存儲在數據庫服務器中,因此稱為存儲過程。

2.存儲過程通常有如下優點:

1) 封裝性

存儲過程被創建後,可以在程序中被多次調用,而不必重新編寫該存儲過程的 SQL 語句,并且數據庫專業人員可以随時對存儲過程進行修改,而不會影響到調用它的應用程序源代碼。

2) 可增強 SQL 語句的功能和靈活性

存儲過程可以用流程控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的運算。

3) 可減少網絡流量

由于存儲過程是在服務器端運行的,且執行速度快,因此當客戶計算機上調用該存儲過程時,網絡中傳送的隻是該調用語句,從而可降低網絡負載。

4) 高性能

存儲過程執行一次後,産生的二進制代碼就駐留在緩沖區,在以後的調用中,隻需要從緩沖區中執行二進制代碼即可,從而提高了系統的效率和性能。

5) 提高數據庫的安全性和數據的完整性

使用存儲過程可以完成所有數據庫操作,并且可以通過編程的方式控制數據庫信息訪問的權限。

MySQL創建存儲過程

語法:

CREATE PROCEDURE 過程名稱([proc_parameter[,...]]) [characteristic ...] routine_body

說明

proc_parameter :表示 [ IN | OUT | INOUT ] param_name type

IN 輸入參數:表示調用者向過程傳入值

OUT 輸出參數:表示過程向調用者傳出值

INOUT 輸入輸出參數:既表示調用者向過程傳入值,又表示過程向調用者傳出值

type :表示任何有效的MySQL數據類型 characteristic :表示 LANGUAGE SQL | [NOT] DETERMINISTIC | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER } | COMMENT 'string' routine_body 表示有效的SQL過程語句或語句 指:“過程體”

1》》NOT DETERMINISTIC :如果程序或線程總是對同樣的輸入參數産生同樣的結果,則被認為它是“确定的”,否則就是“非确定”的。如果既沒有給定DETERMINISTIC也沒有給定NOT DETERMINISTIC,默認的就是NOT DETERMINISTIC。

2》》CONTAINS SQL :表示子程序不包含讀或寫數據的語句

3》》NO SQL表示子程序不包含SQL語句

4》》READS SQL DATA表示子程序包含讀數據的語句,但不包含寫數據的語句

5》》MODIFIES SQL DATA表示子程序包含寫數據的語句

如果這些特征沒有明确給定,默認的是CONTAINS SQL

6》》SQL SECURITY特征可以用來指定 子程序該用創建子程序者的許可來執行,還是使用調用者的許可來執行。默認值是DEFINER。在SQL:2003中者是一個新特性。創建者或調用者必須由訪問 子程序關聯的數據庫的許可。在MySQL 5.1中,必須有EXECUTE權限才能執行子程序。必須擁有這個權限的用戶要麼是定義者,要麼是調用者,這取決于SQL SECURITY特征是如何設置的。

1,要在MySQL 5.1中創建存儲程序,必須具有CREATE ROUTINE權限,并且ALTER ROUTINE和EXECUTE權限被自動授予它的創建者。

2,默認地,子程序與當前數據庫關聯。要明确地把子程序與一個給定數據庫關聯起來,可以在創建子程序的時候指定其名字為db_name.sp_name

接下來 例子說明 in out inout 的使用

1.無參數存儲過程

/*創建一個無參數存儲過程 */ DELIMITER $$ CREATE PROCEDURE a() BEGIN SELECT * FROM a; END$$ DELIMITER $$

說明一下

  1. 聲明語句結束符

DELIMITER $$ 或 DELIMITER //

默認情況下,delimiter是分号;,遇到分号就執行。默認情況下,delimiter是分号;,遇到分号就執行。這是使用雙美元符号再執行

2.聲明存儲過程:

CREATE PROCEDURE a()

3. 存儲過程開始和結束符号:

BEGIN ...... END$$

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)1

2.IN參數存儲過程

/*in 輸入參數的存儲過程 輸入id查詢的行*/ DELIMITER $$ CREATE PROCEDURE b(IN pr_id INT) BEGIN SELECT * FROM a WHERE id=pr_id; END$$ DELIMITER $$

IN 表示這個存儲過程需要需要的參數

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)2

/*調用b的存儲過程*/ CALL b(2);

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)3

說明 調用存儲過程輸入2

/*删除存儲過程*/ DROP PROCEDURE b;

2.out參數存儲過程說明

/*out 的存儲過程的說法*/ DELIMITER $$ CREATE PROCEDURE c(OUT pr_name VARCHAR(20)) BEGIN SELECT NAME INTO pr_name FROM a WHERE id=2; END$$ DELIMITER $$

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)4

調用out的存儲過程

/*調用c的存儲過程 out是輸出,所以調用存儲過程時這是一個變量@name*/ CALL c(@name);

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)5

然後顯示值 SELECT @name

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)6

删除存儲過程

/*删除存儲過程*/ DROP PROCEDURE c;

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)7

3.inout參數存儲過程說明

/*inout的存儲過程的說明*/ DELIMITER$$ CREATE PROCEDURE d(INOUT pr_name VARCHAR(20)) BEGIN SELECT NAME INTO pr_name FROM a WHERE id=pr_name; END$$ DELIMITER $$

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)8

/*調用inout的存儲過程 inout是可以接受一個參數并輸出一個參數 */ /*設置一個參數,@id=5 說明輸入的參數為5*/ SET @id=5;

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)9

/*然後在調用返回輸出一個值*/ CALL d(@id);

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)10

/*顯示存儲過程*/ SELECT @id

mysql的存儲過程和引擎(Mysql存儲過程的詳細講解)11

總結:存儲過程主要有參數模型 in out inout

in 是輸入參數

out是輸出參數

inout是輸入并輸出

謝謝閱讀 可以關注

,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关生活资讯推荐

热门生活资讯推荐

网友关注

Copyright 2023-2025 - www.tftnews.com All Rights Reserved