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