首頁 資料庫 mysql教程 詳解MySQL呼叫預存程序和函數(案例)

詳解MySQL呼叫預存程序和函數(案例)

Mar 26, 2021 am 09:17 AM
mysql

詳解MySQL呼叫預存程序和函數(案例)

預存程序和函數有多種呼叫方法。預存程序必須使用call語句調用,且預存程序和資料庫相關,如果要執行其他資料庫中的預存程序,則需要指定資料庫名稱。例如call dbname.procname。儲存函數的呼叫與MySQL中預先定義的函數的呼叫方式相同。

(免費學習推薦:mysql影片教學#)

1、呼叫預存程序

預存程序是透過call 語句進行呼叫的,語法如下:

call sp_name([parameter[,...])
登入後複製

call語句呼叫先前用create procedure建立的預存程序,其中sp_name為預存程序名稱,parameter為預存程序的參數。

【範例1】定義一個名為CountProcl的預存過程,然後呼叫這個預存程序。

定義預存程序:

mysql> delimiter //mysql> create procedure CountProcl(in sid int ,out num int)
    -> begin
    -> select count(*) into num from fruits where s_id = sid;
    -> end //Query OK, 0 rows affected (0.06 sec)mysql> delimiter ;
登入後複製

呼叫預存程序:

mysql> call CountProcl (101,@num);Query OK, 1 row affected (0.08 sec)
登入後複製

查看傳回結果:

mysql> select @num;+------+| @num |+------+|    3 |+------+1 row in set (0.00 sec)
登入後複製

此預存程序傳回了指定s_id=101的水果商數提供的水果種類,回傳值儲存在num變數中,使用select查看,回傳結果為3。

2、呼叫儲存函數

在MySQL中,儲存函數的使用方法與MySQL內部函數的使用方法是一樣的。即使用者自訂的儲存函數與MySQL內部函數是一個性質的。

【範例2】定義儲存函數CountProc2,然後呼叫這個函數,程式碼如下:

mysql> delimiter //mysql> create function CountProc2 (sid int)
    -> returns int
    -> begin
    -> return (select count(*) from fruits where s_id = sid);
    -> end//Query OK, 0 rows affected (0.06 sec)mysql> delimiter ;
登入後複製

呼叫儲存函數:

mysql> delimiter ;mysql> select CountProc2(101);+-----------------+| CountProc2(101) |+-----------------+|               3 |+-----------------+1 row in set (0.05 sec)
登入後複製

可以看到,該範例與上一個範例中傳回的結果相同,雖然儲存函數和預存程序的定義稍有不同,但可以實現相同的功能。

更多相關免費學習推薦:mysql教學##(影片)

#

以上是詳解MySQL呼叫預存程序和函數(案例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP 的大數據結構處理技巧 PHP 的大數據結構處理技巧 May 08, 2024 am 10:24 AM

PHP 的大數據結構處理技巧

如何優化 PHP 中的 MySQL 查詢效能? 如何優化 PHP 中的 MySQL 查詢效能? Jun 03, 2024 pm 08:11 PM

如何優化 PHP 中的 MySQL 查詢效能?

如何在 PHP 中使用 MySQL 備份和還原? 如何在 PHP 中使用 MySQL 備份和還原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 備份和還原?

如何使用 PHP 插入資料到 MySQL 表? 如何使用 PHP 插入資料到 MySQL 表? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入資料到 MySQL 表?

Java 枚舉類型在資料庫中的應用場景有哪些? Java 枚舉類型在資料庫中的應用場景有哪些? May 05, 2024 am 09:06 AM

Java 枚舉類型在資料庫中的應用場景有哪些?

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 Dec 09, 2024 am 11:42 AM

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤

如何在 PHP 中使用 MySQL 預存程序? 如何在 PHP 中使用 MySQL 預存程序? Jun 02, 2024 pm 02:13 PM

如何在 PHP 中使用 MySQL 預存程序?

如何使用 PHP 建立 MySQL 表? 如何使用 PHP 建立 MySQL 表? Jun 04, 2024 pm 01:57 PM

如何使用 PHP 建立 MySQL 表?

See all articles