? create procedure用來創(chuàng)建 存儲(chǔ)過程 ,create function用來創(chuàng)建 函數(shù)

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了靈寶免費(fèi)建站歡迎大家使用!
? Delimiter命令是改變語句的結(jié)束符 ,MySQL默認(rèn)的結(jié)束符為;號(hào),由于procedure和function中的;號(hào)并不代表創(chuàng)建的結(jié)束,所以要替換成另外的結(jié)束符以便表示創(chuàng)建的結(jié)束
? rontine_body子句可以包含一個(gè)簡(jiǎn)單的SQL語句,也可以包含多個(gè)SQL語句, 通過begin…end將這多個(gè)SQL語句 包含在一起
? MySQL存儲(chǔ)過程和函數(shù)中也可以包含類似create和drop等DDL語句
? comment子句用來寫入對(duì)存儲(chǔ)過程和函數(shù)的注釋
? Language子句用來表示此存儲(chǔ)過程和函數(shù)的創(chuàng)建語言
? 存儲(chǔ)過程和函數(shù)被標(biāo)注為deterministic表明當(dāng)輸入相同的參數(shù)是會(huì)返回相同的結(jié)果,反之如果是not deterministic則表示相同參數(shù)不會(huì)是相同結(jié)果,默認(rèn)是not deterministic
? 相關(guān)屬性短語只有咨詢含義,并不是強(qiáng)制性的約束
? Drop procedure/function語句用來 刪除指定名稱的存儲(chǔ)過程或函數(shù)
? Begin…end語句通常出現(xiàn)在存儲(chǔ)過程、函數(shù)和觸發(fā)器中,其中 可以包含一個(gè)或多個(gè)語句 ,每個(gè)語句用;號(hào)隔開
? 標(biāo)簽label可以加在begin…end語句以及l(fā)oop, repeat和while語句
? 語句中通過iterate和leave來控制流程,iterate表示返回指定標(biāo)簽位置,leave表示跳出標(biāo)簽
? Declare語句通常用來聲明本地變量、游標(biāo)、條件或者h(yuǎn)andler
? Declare語句只允許出現(xiàn)在begin … end語句中而且必須出現(xiàn)在第一行
? Declare的順序也有要求,通常是先聲明本地變量,再是游標(biāo),然后是條件和handler
? 本地變量可以通過declare語句進(jìn)行聲明
? 聲明后的變量可以通過select … into var_list進(jìn)行賦值,或者通過set語句賦值,或者通過定義游標(biāo)并使用fetch … into var_list賦值
? 通過declare聲明變量方法:
? MySQL支持if,case,iterate,leave,loop,while,repeat語句作為存儲(chǔ)過程和函數(shù)中的 流程控制語句 ,另外return語句也是函數(shù)中的特定流程控制語句
? Case語句在存儲(chǔ)過程或函數(shù)中表明了 復(fù)雜的條件選擇語句
? IF語句在存儲(chǔ)過程或函數(shù)中表明了 基礎(chǔ)的條件選擇語句
其中在 function 里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我們開啟了 bin-log, 我們就必須為我們的 function 指定一個(gè)參數(shù)。
在 MySQL 中創(chuàng)建函數(shù)時(shí)出現(xiàn)這種錯(cuò)誤的解決方法:
set global log_bin_trust_function_creators=TRUE;
? Iterate語句 僅出現(xiàn)在loop,repeat,while循環(huán)語句中,其含義表示重新開始此循環(huán)
? Leave語句表明 退出指定標(biāo)簽的流程控制語句塊
? 通常會(huì)用在begin…end,以及l(fā)oop,repeat,while的循環(huán)語句中
? Loop語句是存儲(chǔ)過程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? repeat語句是存儲(chǔ)過程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? while語句是存儲(chǔ)過程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? Return語句用在 函數(shù)中,用來終結(jié)函數(shù)的執(zhí)行并將指定值返回給調(diào)用者
? Cursor游標(biāo)用來 聲明一個(gè)數(shù)據(jù)集
? 游標(biāo)的聲明必須在變量和條件聲明之后,在handler聲明之前
? Cursor close語句用來 關(guān)閉之前打開的游標(biāo)
? Cursor declare語句用來聲明一個(gè)游標(biāo)和指定游標(biāo)對(duì)應(yīng)的數(shù)據(jù)集合, 通常數(shù)據(jù)集合是一個(gè)select語句
? Cursor fetch語句用來獲取游標(biāo)指定數(shù)據(jù)集的 下一行數(shù)據(jù) 并將各個(gè)字段值賦予后面的變量
? Open cursor語句用來打開一個(gè)之前已經(jīng) 聲明好的游標(biāo)
? Declare condition語句命名 特定的錯(cuò)誤條件 ,而該特定錯(cuò)誤可以在declare…h(huán)andler中指定 處理方法
? 比如在MySQL中1051error code表示的是unknown table的錯(cuò)誤,如果要對(duì)這
個(gè)錯(cuò)誤做特殊處理,可以用三種方法:
? Declare handler語句用來聲明一個(gè)handler來處理一個(gè)或多個(gè)特殊條件,當(dāng)其中的某個(gè)條件滿足時(shí)則觸發(fā)其中的statement語句執(zhí)行
? Statement可以是一個(gè)簡(jiǎn)單SQL語句,也可以是begin…end組成的多個(gè)語句
? Handler_action子句聲明當(dāng)執(zhí)行完statement語句之后應(yīng)該怎么辦
Condition_value的值有以下幾種:
? 當(dāng)condition發(fā)生但沒有聲明handler時(shí),則存儲(chǔ)過程和函數(shù)依照如下規(guī)則處理
? create trigger語句用來創(chuàng)建一個(gè)觸發(fā)器,觸發(fā)器的作用是當(dāng)表上有對(duì)應(yīng)SQL語句發(fā)生時(shí),則觸發(fā)執(zhí)行
? 觸發(fā)器創(chuàng)建時(shí)需要 指定對(duì)應(yīng)的表名 tbl_name
? Definer關(guān)鍵詞用來指定trigger的安全環(huán)境
? Trigger_time指定觸發(fā)器的執(zhí)行時(shí)間,BEFORE和AFTER指定觸發(fā)器在表中的 每行數(shù)據(jù)修改前或者后 執(zhí)行
? Trigger_event指定觸發(fā)該觸發(fā)器的具體 事件
? INSERT當(dāng)新的一行數(shù)據(jù)插入表中時(shí)觸發(fā),比如通過執(zhí)行insert,load data,replace語句插入新數(shù)據(jù)
? UPDATE當(dāng)表的一行數(shù)據(jù)被修改時(shí)觸發(fā),比如執(zhí)行update語句時(shí)
? DELETE當(dāng)表的一行數(shù)據(jù)被刪除時(shí)觸發(fā),比如執(zhí)行delete,replace語句時(shí)
? 當(dāng)執(zhí)行insert into … on duplicate key update語句時(shí),當(dāng)碰到重復(fù)行執(zhí)行update時(shí),則觸發(fā)update下的觸發(fā)器
? 從5.7.2版本開始,可以創(chuàng)建具有相同trigger_time和trigger_event的同一個(gè)表上的多個(gè)觸發(fā)器,默認(rèn)情況下按照創(chuàng)建的時(shí)間依次執(zhí)行,通過 指定FOLLOWS/PRECEDES改變執(zhí)行順序 ,即FOLLOWS時(shí)表示新創(chuàng)建的觸發(fā)器后執(zhí)行,PRECEDES則表示新觸發(fā)器先執(zhí)行
? Trigger_body表示觸發(fā)器觸發(fā)之后要執(zhí)行的一個(gè)或多個(gè)語句,在內(nèi)部可以引用涉及表的字段, OLD.col_name表示行數(shù)據(jù)被修改或刪除之前的字段數(shù)據(jù),NEW.col_name表示行數(shù)據(jù)被插入或修改之后的字段數(shù)據(jù)
? Drop trigger語句用來 刪除一個(gè)觸發(fā)器
? If exists短語用來避免刪除不存在的觸發(fā)器時(shí)引發(fā)報(bào)錯(cuò)
? 當(dāng)你執(zhí)行drop table時(shí),表上的觸發(fā)器也被drop掉了
語法:Create function function_name(參數(shù)列表)returns返回值類型
函數(shù)體 函數(shù)名,應(yīng)合法的標(biāo)識(shí)符,不應(yīng)與系統(tǒng)關(guān)鍵字沖突。
一個(gè)函數(shù)應(yīng)該屬于某個(gè)數(shù)據(jù)庫(kù),可以使用db_name.funciton_name的形式執(zhí)行當(dāng)前函數(shù)所屬數(shù)據(jù)庫(kù),否則為當(dāng)前數(shù)據(jù)庫(kù)。
參數(shù)部分,由參數(shù)名和參數(shù)類型組成。
返回值類類型.注意,一定要有return返回值語句。
創(chuàng)建第一個(gè)函數(shù):
mysql DROP FUNCTION IF EXISTS SP_FUNC_DBDH_ONE ?-- 刪掉已存在函數(shù) DELIMITER -- 定義分隔符,必須要有 ,本例為 可以為得數(shù)字符,例如: $$,%%,**
mysql CREATE FUNCTION SP_FUNC_DBDH_ONE( PARA_VAR varchar(30)) -- 多個(gè)參數(shù)用,分割 參數(shù)
的類型必須是mysql列存在的類型
- RETURNS VARCHAR(100) ? ? ? ? ? ? ? ? ?-- 指定返回值類型,如果你不確定返回
文本長(zhǎng)度,可以使用text
- BEGIN
- ? ? DECLARE NAYIBU_FIR VARCHAR(30) DEFAULT 'THIS IS MY FIRST,'; ? -- 定義變量,設(shè)置默認(rèn)值
- ? ? SET NAYIBU_FIR = concat(NAYIBU_FIR,PARA_VAR);
- ? ? RETURN NAYIBU_FIR; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? -- 返回值
- END $$ ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
后面有你在前面定義的分割符號(hào)
Query OK, 0 rows affected (0.00 sec)
mysql DELIMITER
調(diào)用自定義函數(shù),輸出結(jié)果如下:
mysql SELECT SP_FUNC_DBDH_ONE('PROGRAM');
+------------------------------+
| SP_FUNC_DBDH_ONE('PROGRAM') |
+------------------------------+
| 'THIS IS MY FIRST, PROGRAM ? ? ? ?|
+------------------------------+
1 row in set (0.00 sec)
在使用mysql的過程中,mysql自帶的函數(shù)可能不能完成我們的業(yè)務(wù)需求,這時(shí)就需要自定義函數(shù),
函數(shù)包括數(shù)學(xué)函數(shù)、字符串函數(shù)、日期和時(shí)間函數(shù)、條件判斷函數(shù)、系統(tǒng)信息函數(shù)、加密函數(shù)、格式化函數(shù)等。通過這些函數(shù),可以簡(jiǎn)化用戶的操作。
在MySQL——函數(shù)的使用方法與MySQL內(nèi)部函數(shù)的使用方法一樣。
DELIMITER $$
CREATE FUNCTION `ChkInsert`(in_pk int) returns int
begin
declare _count int;
declare _returnValue int;
set _count = 0;
select count(列1) into _count from 你的表 where 列1 = in_pk;
if _count 0 then
set _returnValue = 2;
else
insert into 你的表 ( 列1 ) values ( in_pk );
set _returnValue = 0;
end if;
return _returnValue;
end $$
文章標(biāo)題:怎么創(chuàng)建mysql函數(shù) mysql數(shù)據(jù)庫(kù)創(chuàng)建函數(shù)語法
鏈接分享:http://chinadenli.net/article24/dojgsce.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、小程序開發(fā)、ChatGPT、網(wǎng)站設(shè)計(jì)、標(biāo)簽優(yōu)化、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)