日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

MySQL的存储函数与存储过程的区别

發(fā)布時(shí)間:2023/12/10 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL的存储函数与存储过程的区别 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

MySQL存儲(chǔ)函數(shù)(自定義函數(shù)),函數(shù)一般用于計(jì)算和返回一個(gè)值,可以將經(jīng)常需要使用的計(jì)算或功能寫成一個(gè)函數(shù)。

存儲(chǔ)函數(shù)和存儲(chǔ)過(guò)程一樣,都是在數(shù)據(jù)庫(kù)中定義一些 SQL 語(yǔ)句的集合。

存儲(chǔ)函數(shù)與存儲(chǔ)過(guò)程的區(qū)別

1.存儲(chǔ)函數(shù)有且只有一個(gè)返回值,而存儲(chǔ)過(guò)程可以有多個(gè)返回值,也可以沒有返回值。

2.存儲(chǔ)函數(shù)只能有輸入?yún)?shù),而且不能帶in, 而存儲(chǔ)過(guò)程可以有多個(gè)in,out,inout參數(shù)。

3.存儲(chǔ)過(guò)程中的語(yǔ)句功能更強(qiáng)大,存儲(chǔ)過(guò)程可以實(shí)現(xiàn)很復(fù)雜的業(yè)務(wù)邏輯,而函數(shù)有很多限制,如不能在函數(shù)中使用insert,update,delete,create等語(yǔ)句;

4.存儲(chǔ)函數(shù)只完成查詢的工作,可接受輸入?yún)?shù)并返回一個(gè)結(jié)果,也就是函數(shù)實(shí)現(xiàn)的功能針對(duì)性比較強(qiáng)。

5.存儲(chǔ)過(guò)程可以調(diào)用存儲(chǔ)函數(shù)、但函數(shù)不能調(diào)用存儲(chǔ)過(guò)程。

6.存儲(chǔ)過(guò)程一般是作為一個(gè)獨(dú)立的部分來(lái)執(zhí)行(call調(diào)用)。而函數(shù)可以作為查詢語(yǔ)句的一個(gè)部分來(lái)調(diào)用.

create function func_name ([param_name type[,...]]) returns type [characteristic ...] beginroutine_body end;

參數(shù)說(shuō)明:
(1)func_name :存儲(chǔ)函數(shù)的名稱。
(2)param_name type:可選項(xiàng),指定存儲(chǔ)函數(shù)的參數(shù)。type參數(shù)用于指定存儲(chǔ)函數(shù)的參數(shù)類型,該類型可以是MySQL數(shù)據(jù)庫(kù)中所有支持的類型。
(3)RETURNS type:指定返回值的類型。
(4)characteristic:可選項(xiàng),指定存儲(chǔ)函數(shù)的特性。
(5)routine_body:SQL代碼內(nèi)容。

create database mydb9_function; -- 導(dǎo)入測(cè)試數(shù)據(jù) use mydb9_function; set global log_bin_trust_function_creators=TRUE; -- 信任子程序的創(chuàng)建者-- 創(chuàng)建存儲(chǔ)函數(shù)-沒有輸輸入?yún)?shù) drop function if exists myfunc1_emp;delimiter $$ create function myfunc1_emp() returns int begindeclare cnt int default 0;select count(*) into cnt from emp;return cnt; end $$ delimiter ; -- 調(diào)用存儲(chǔ)函數(shù) select myfunc1_emp(); -- 創(chuàng)建存儲(chǔ)過(guò)程-有輸入?yún)?shù)drop function if exists myfunc2_emp; delimiter $$ create function myfunc2_emp(in_empno int) returns varchar(50) begindeclare out_name varchar(50);select ename into out_name from emp where empno = in_empno;return out_name; end $$ delimiter ;select myfunc2_emp(1008);

每文一語(yǔ)

適合自己的才是最好的

總結(jié)

以上是生活随笔為你收集整理的MySQL的存储函数与存储过程的区别的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。