mysql創(chuàng)建存儲過程及函數(shù)詳解
1. 存儲過程
1.1. 基本語法
create procedure name ([params]) UNSIGNED [characteristics] routine_body
?params : in|out|inout 指定參數(shù)列表 代表輸入與輸出
routine_body: SQL代碼內(nèi)容,以begin ........? ?end
characteristics: 指定存儲過程特性,包含5種
? ? ? ? ? ? ? ? ? ? ? ? ? ?1 DETERMINISTIC 不確定的
2 NO SQL 沒有SQl語句,當(dāng)然也不會修改數(shù)據(jù)
3 READS SQL DATA 只是讀取數(shù)據(jù),當(dāng)然也不會修改數(shù)據(jù)
4 MODIFIES SQL DATA 要修改數(shù)據(jù)
5 CONTAINS SQL 包含了SQL語句
1.2 創(chuàng)建一個指定執(zhí)行權(quán)限的存儲過程
create DEFINER=`root`@`%` procedure name ([params]) UNSIGNED [characteristics] routine_body
DEFINER:指明誰有權(quán)力來執(zhí)行。
1.3?DELIMITER 的使用
? ? ? ”DELIMITER //“ 表示設(shè)置“//”符號為結(jié)束語,因?yàn)閙ysql中默認(rèn)語句結(jié)束為分號‘;',為了避免存儲過程與mysql語句符號沖突,所以有時使用DELIMITER來改變結(jié)束語符號,要配合end //來使用;
?示例:創(chuàng)建一個root賬戶執(zhí)行的存儲過程,輸出給定字符串的長度
DELIMITER // CREATE definer=`root`@`%` PROCEDURE `avgFruitPrice`( in f_string VARCHAR(200) ) BEGIN select length(f_string); END//
2. 創(chuàng)建函數(shù)?
函數(shù)的創(chuàng)建與存儲過程相同
示例
DELIMITER // CREATE definer=`root`@`%` FUNCTION `my_length`( f_string VARCHAR(200) ) RETURNS INT(11) UNSIGNED NO SQL BEGIN return length(f_string); END//
注意: 創(chuàng)建函數(shù)需要注意3個地方,
1.??RETURNS: 需指定返回類型
2.?UNSIGNED ?NO SQL 需指定存儲過程特性
3.return: 返回需要的數(shù)據(jù)
遇見的錯誤:
如報錯如上信息就是沒有指定存儲過程特性。
存儲過程函數(shù)中可以通過mysql查詢結(jié)果為其參數(shù)復(fù)制: 其語句為select .... into
begin declare onename char(50) default‘0'; declare twoname char(50); select f_name, b_name into onename, twoname from t_user where id =1; ....... end//
說明:
declare: 存儲過程及函數(shù)內(nèi)部定義變量
default:默認(rèn)值
到此這篇關(guān)于mysql創(chuàng)建存儲過程及函數(shù)詳解的文章就介紹到這了,更多相關(guān)mysql存儲過程及函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySql存儲過程循環(huán)的使用分析詳解
- Mysql 存儲過程中使用游標(biāo)循環(huán)讀取臨時表
- 詳解MySql存儲過程參數(shù)的入門使用
- MySQL存儲過程中使用WHILE循環(huán)語句的方法
- Mysql存儲過程循環(huán)內(nèi)嵌套使用游標(biāo)示例代碼
- 詳解MySQL存儲過程的創(chuàng)建和調(diào)用
- MySQL之存儲過程按月創(chuàng)建表的方法步驟
- mysql存儲過程之創(chuàng)建(CREATE PROCEDURE)和調(diào)用(CALL)及變量創(chuàng)建(DECLARE)和賦值(SET)操作方法
- MySQL動態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲過程
- MySQL存儲過程的創(chuàng)建和使用示例詳解
相關(guān)文章
MySQL在生產(chǎn)環(huán)境出現(xiàn)無法啟動的問題解決
在當(dāng)今的數(shù)據(jù)驅(qū)動世界中,MySQL作為廣泛應(yīng)用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在眾多生產(chǎn)環(huán)境中承擔(dān)著至關(guān)重要的角色,然而,面對復(fù)雜多變的業(yè)務(wù)場景,MySQL可能會遭遇各類故障和性能瓶頸,本文將深入探討MySQL在生產(chǎn)環(huán)境出現(xiàn)無法啟動的問題解決,需要的朋友可以參考下2024-10-10mysql 搜尋附近N公里內(nèi)數(shù)據(jù)的簡單實(shí)例
下面小編就為大家?guī)硪黄猰ysql 搜尋附近N公里內(nèi)數(shù)據(jù)的簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04mysql如何在已有數(shù)據(jù)庫上統(tǒng)一字符集
這篇文章主要介紹了mysql如何在已有數(shù)據(jù)庫基礎(chǔ)上換字符集,數(shù)據(jù)庫里面,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是latin1的,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是UTF8,還有部分表,表結(jié)構(gòu)是utf8而數(shù)據(jù)是latin1,下面說一下,怎么樣字符集統(tǒng)一成utf8,需要的朋友可以參考下2019-06-06MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解
這篇文章主要介紹了MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程,解讀了Slave的一些相關(guān)配置,需要的朋友可以參考下2015-11-11解讀sql中timestamp和datetime之間的轉(zhuǎn)換
這篇文章主要介紹了解讀sql中timestamp和datetime之間的轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12