Mysql自定義函數(CREATE FUNCTION)


在使用 MySQL 的過程中,MySQL 自帶的函數可能完成不了我們的業務需求,這時候就需要自定義函數。

自定義函數是一種與存儲過程十分相似的過程式數據庫對象。它與存儲過程一樣,都是由 SQL 語句和過程式語句組成的代碼片段,並且可以被應用程序和其他 SQL 語句調用。

自定義函數與存儲過程之間存在幾點區別:

    • 自定義函數不能擁有輸出參數,這是因為自定義函數自身就是輸出參數;而存儲過程可以擁有輸出參數。
    • 自定義函數中必須包含一條 RETURN 語句,而這條特殊的 SQL 語句不允許包含於存儲過程中。
    • 可以直接對自定義函數進行調用而不需要使用 CALL 語句,而對存儲過程的調用需要使用 CALL 語句。

一、創建與使用自定義函數

可以使用 CREATE FUNCTION 語句創建自定義函數。

語法格式如下:

CREATE FUNCTION <函數名> ( [ <參數1> <類型1> [ , <參數2> <類型2>] ] … )
  RETURNS <類型>
  <函數主體>

語法說明如下:

  • <函數名>:指定自定義函數的名稱。注意,自定義函數不能與存儲過程具有相同的名稱。
  • <參數><類型>:用於指定自定義函數的參數。這里的參數只有名稱和類型,不能指定關鍵字 IN、OUT 和 INOUT。
  • RETURNS<類型>:用於聲明自定義函數返回值的數據類型。其中,<類型>用於指定返回值的數據類型。
  • <函數主體>:自定義函數的主體部分,也稱函數體。所有在存儲過程中使用的 SQL 語句在自定義函數中同樣適用,包括前面所介紹的局部變量、SET 語句、流程控制語句、游標等。除此之外,自定義函數體還必須包含一個 RETURN<值> 語句,其中<值>用於指定自定義函數的返回值。

在 RETURN VALUE 語句中包含 SELECT 語句時,SELECT 語句的返回結果只能是一行且只能有一列值。

若要查看數據庫中存在哪些自定義函數,可以使用 SHOW FUNCTION STATUS 語句;若要查看數據庫中某個具體的自定義函數,可以使用 SHOW CREATE FUNCTION<函數名> 語句,其中<函數名>用於指定該自定義函數的名稱。

【實例 1】創建存儲函數,名稱為 StuNameById,該函數返回 SELECT 語句的查詢結果,數值類型為字符串類型,輸入的 SQL 語句和執行結果如下所示。

mysql> CREATE FUNCTION StuNameById()
    -> RETURNS VARCHAR(45)
    -> RETURN
    -> (SELECT name FROM tb_students_info
    -> WHERE id=1);
Query OK, 0 rows affected (0.09 sec)

注意:當使用 DELIMITER 命令時,應該避免使用反斜杠“\”字符,因為反斜杠是 MySQL 的轉義字符。

成功創建自定義函數后,就可以如同調用系統內置函數一樣,使用關鍵字 SELECT 調用用戶自定義的函數,語法格式為:

SELECT <自定義函數名> ([<參數> [,...]])

【實例 2】調用自定義函數 StuNameById,查看函數的運行結果,如下所示。

mysql> SELECT StuNameById();
+---------------+
| StuNameById() |
+---------------+
| Dany          |
+---------------+
1 row in set (0.24 sec)

二、修改自定義函數

可以使用 ALTER FUNCTION 語句來修改自定義函數的某些相關特征。若要修改自定義函數的內容,則需要先刪除該自定義函數,然后重新創建。

三、刪除自定義函數

自定義函數被創建后,一直保存在數據庫服務器上以供使用,直至被刪除。刪除自定義函數的方法與刪除存儲過程的方法基本一樣,可以使用 DROP FUNCTION 語句來實現。

語法格式如下:

DROP FUNCTION [ IF EXISTS ] <自定義函數名>

語法說明如下。
<自定義函數名>:指定要刪除的自定義函數的名稱。
IF EXISTS:指定關鍵字,用於防止因誤刪除不存在的自定義函數而引發錯誤。

【實例 3】刪除自定義函數 StuNameById,查看函數的運行結果,如下所示。

mysql> DROP FUNCTION StuNameById;
Query OK, 0 rows affected (0.09 sec)
mysql> SELECT StuNameById();
ERROR 1305 (42000): FUNCTION test_db.StuNameById does not exist

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM