在使用 mysql 的過程中,mysql 自帶的函式可能完成不了我們的業務需求,這時候就需要自定義函式。
自定義函式是一種與儲存過程十分相似的過程式資料庫物件。它與儲存過程一樣,都是由 sql 語句和過程式語句組成的**片段,並且可以被應用程式和其他 sql 語句呼叫。
自定義函式與儲存過程之間存在幾點區別:
可以使用 create function 語句建立自定義函式。
語法格式如下:
create
function
《函式名》([
《引數1
>
《型別1
>[,
《引數2
>
《型別2
>
]] … )
returns
《型別》
《函式主體》
語法說明如下:
在 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 |
+---------------+
1row
inset
(0.24 sec)
可以使用 alter function 語句來修改自定義函式的某些相關特徵。若要修改自定義函式的內容,則需要先刪除該自定義函式,然後重新建立。
自定義函式被建立後,一直儲存在資料庫伺服器上以供使用,直至被刪除。刪除自定義函式的方法與刪除儲存過程的方法基本一樣,可以使用 drop function 語句來實現。
語法格式如下:
drop
function[if
exists
]《自定義函式名》
語法說明如下。
【例項 3】刪除自定義函式 stunamebyid,檢視函式的執行結果,如下所示。
mysql>
drop
function stunamebyid;
query ok,
0rows 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...