MySQL 自定義函式

2021-10-03 20:58:14 字數 2651 閱讀 4671

在使用 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《函式名》 語句,其中《函式名》用於指定該自定義函式的名稱。

建立儲存函式,名稱為 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 《自定義函式名》([

《引數》[,

...]

])

呼叫自定義函式 stunamebyid,檢視函式的執行結果,如下所示。

mysql> select stunamebyid()

;+----

----

-------

+|stunamebyid()

|+----

----

-------

+| dany |+--

----

----

-----+

1 row in set (

0.24 sec)

可以使用 alter function 語句來修改自定義函式的某些相關特徵。若要修改自定義函式的內容,則需要先刪除該自定義函式,然後重新建立。

自定義函式被建立後,一直儲存在資料庫伺服器上以供使用,直至被刪除。刪除自定義函式的方法與刪除儲存過程的方法基本一樣,可以使用 drop function 語句來實現。

語法格式如下:

drop function [ if exists ]

《自定義函式名》

語法說明如下。

《自定義函式名》:指定要刪除的自定義函式的名稱。

if exists:指定關鍵字,用於防止因誤刪除不存在的自定義函式而引發錯誤。

刪除自定義函式 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

mysql自定義函式優點 MySQL自定義函式

在使用 mysql 的過程中,mysql 自帶的函式可能完成不了我們的業務需求,這時候就需要自定義函式。自定義函式是一種與儲存過程十分相似的過程式資料庫物件。它與儲存過程一樣,都是由 sql 語句和過程式語句組成的 片段,並且可以被應用程式和其他 sql 語句呼叫。自定義函式與儲存過程之間存在幾點區...

mysql自定義函式命名 MySQL自定義函式

在使用 mysql 的過程中,mysql 自帶的函式可能完成不了我們的業務需求,這時候就需要自定義函式。自定義函式是一種與儲存過程十分相似的過程式資料庫物件。它與儲存過程一樣,都是由 sql 語句和過程式語句組成的 片段,並且可以被應用程式和其他 sql 語句呼叫。自定義函式與儲存過程之間存在幾點區...

mysql 自定義函式

今天要做乙個排序,有中文和英文的,資料庫採用utf8編碼,排除來的不對,所以需要將中文轉換成中文的第乙個字母,然後來排序 先小小的看一下mysql的自定義函式 drop function if exists fntable 如果存在就刪除 delimiter 函式開始 create function...