欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL存儲過程輸入?yún)?shù)(in),輸出參數(shù)(out),輸入輸出參數(shù)(inout)

 更新時間:2022年07月11日 16:30:45   作者:王小王_123???????  
這篇文章主要介紹了MySQL存儲過程輸入?yún)?shù)(in),輸出參數(shù)(out),輸入輸出參數(shù)(inout),存儲過程就是一組SQL語句集,功能強大,可以實現(xiàn)一些比較復雜的邏輯功能,類似于JAVA語言中的方法;Python里面的函數(shù)

什么是存儲過程?

MySQL 5.0 版本開始支持存儲過程。

簡單的說,存儲過程就是一組SQL語句集,功能強大,可以實現(xiàn)一些比較復雜的邏輯功能,類似于JAVA語言中的方法;Python里面的函數(shù);

存儲過就是數(shù)據(jù)庫 SQL 語言層面的代碼封裝與重用。

特點:

有輸入輸出參數(shù),可以聲明變量,有if/else, case,while等控制語句,通過編寫存儲過程,可以實現(xiàn)復雜的邏輯功能;

函數(shù)的普遍特性:模塊化,封裝,代碼復用;

速度快,只有首次執(zhí)行需經過編譯和優(yōu)化步驟,后續(xù)被調用可以直接執(zhí)行,省去以上步驟;

語法格式

delimiter 自定義結束符號
create procedure 儲存名([ in ,out ,inout ] 參數(shù)名 數(shù)據(jù)類形...)
begin
sql語句
end 自定義的結束符合
delimiter ;
delimiter $$
create procedure proc01()
begin
select empno,ename from emp;
end $$
delimiter ;
-- 調用存儲過程
call proc01();

注意創(chuàng)建的時候需要指定delimiter $$(自定義的,但是通常使用這個),然后使用create procedure 儲存名(有輸入?yún)?shù) 輸出參數(shù)) 然后記住有begin 和end 之間就寫SQL語句,并且需要在end后面加上$$,最后用delimiter ;

局部變量

用戶自定義,在begin/end塊中有效 ,也就是相對于在函數(shù)內部中聲明變量

  • 語法: 聲明變量 declare var_name type [default var_value];
  • 舉例:declare nickname varchar(32);

關鍵詞:declare 變量名 類型(長度)可以加默認值——類似于我們python或者java中的 int a=10;

delimiter $$
create procedure proc02()
begin
declare var_name01 varchar(20) default ‘aaa'; -- 定義局部變量
set var_name01 = ‘zhangsan';
select var_name01;
end $$
delimiter ;
-- 調用存儲過程
call proc02();

定義變量之后,使用set給變量賦值

MySQL 中還可以使用 SELECT..INTO 語句為變量賦值。

其基本語法如下:

select col_name [...] into var_name[,...]
from table_name wehre condition

其中:

  • col_name 參數(shù)表示查詢的字段名稱;
  • var_name 參數(shù)是變量的名稱;
  • table_name 參數(shù)指表的名稱;
  • condition 參數(shù)指查詢條件。

注意:當將查詢結果賦值給變量時,該查詢語句的返回結果只能是單行單列(單元格值)

delimiter $$
create procedure proc03()
begin
declare my_ename varchar(20) ;
select ename into my_ename from emp where empno=1001;
select my_ename;
end $$
delimiter ;
-- 調用存儲過程
call proc03();

如果是在內部聲明的變量,并且進行了賦值之后,那么在內部調用顯示的時候,可以直接select就可以實現(xiàn)展示數(shù)據(jù)的效果

用戶變量

用戶自定義,當前會話(連接)有效。類比java的成員變量

語法:

@var_name

不需要提前聲明,使用即聲明

delimiter $$
create procedure proc04()
begin
set @var_name01 = 'ZS';
end $$
delimiter;
call proc04() ;
select @var_name01 ; --可以看到結果

這里使用@進行聲明,前提不需要對其類型進行聲明,直接可以賦值,但是調用的時候也需要@變量名

聲明一般有兩種方法:

1、declare 變量名 類型(長度)

  • 然后使用set 變量名 = 值 接收
  • 或者使用新值 into 變量名

2、直接使用@變量名=?

  • 但是這個在整個會話都有作用,調用的時候需要使用@變量名

系統(tǒng)變量

系統(tǒng)變量又分為全局變量與會話變量

全局變量在MYSQL啟動的時候由服務器自動將它們初始化為默認值,這些默認值可以通過更改my.ini這個文件來更改。

會話變量在每次建立一個新的連接的時候,由MYSQL來初始化。MYSQL會將當前所有全局變量的值復制一份。來做為會話變量。

也就是說,如果在建立會話以后,沒有手動更改過會話變量與全局變量的值,那所有這些變量的值都是一樣的。

全局變量與會話變量的區(qū)別就在于,對全局變量的修改會影響到整個服務器,但是對會話變量的修改,只會影響到當前的會話(也就是當前的數(shù)據(jù)庫連接)。

有些系統(tǒng)變量的值是可以利用語句來動態(tài)進行更改的,但是有些系統(tǒng)變量的值卻是只讀的,對于那些可以更改的系統(tǒng)變量,我們可以利用set語句進行更改。

查看修改全局變量:

-- 查看全局變量
show global variables;
-- 查看某全局變量
select @@global.auto_increment_increment;
-- 修改全局變量的值
set global sort_buffer_size = 40000;
set @@global.sort_buffer_size = 40000;

查看修改會話變量:

-- 查看會話變量
show session variables;
-- 查看某會話變量
select @@session.auto_increment_increment;
-- 修改會話變量的值
set session sort_buffer_size = 50000;
set @@session.sort_buffer_size = 50000 ;

傳入?yún)?shù)

in 表示傳入的參數(shù), 可以傳入數(shù)值或者變量,即使傳入變量,并不會更改變量的值,可以內部更改,僅僅作用在函數(shù)范圍內。

注意:這里參入?yún)?shù)如果和字段名一樣的話,一般不要命名一樣的名字,如果不小心命名一樣的,那么也需要在表中指定,表.字段

而且需要注意的是聲明輸入?yún)?shù):in 參數(shù)名 類型(長度)

-- 封裝有參數(shù)的存儲過程,傳入員工編號,查找員工信息
delimiter $$
create procedure dec_param01(in param_empno varchar(20))
begin
select * from emp where empno = param_empno;
end $$
delimiter ;
call dec_param01('1001');
-- 封裝有參數(shù)的存儲過程,可以通過傳入部門名和薪資,查詢指定部門,并且薪資大于指定值的員工信息
delimiter $$
create procedure dec_param0x(in dname varchar(50),in sal decimal(7,2),)
begin
select * from dept a, emp b where b.sal > sal and a.dname = dname;
end $$
delimiter ;
call dec_param0x('學工部',20000);

通過上述的案例,我們也可以發(fā)現(xiàn),一般如果傳入?yún)?shù)的時候,是字符串就用varchar(),如果是數(shù)值就用decimal(),當然有時候也可以使用數(shù)值類型,字符類型。

輸出參數(shù)

out 表示從存儲過程內部傳值給調用者

-- ---------傳出參數(shù):out---------------------------------
use mysql7_procedure;
-- 封裝有參數(shù)的存儲過程,傳入員工編號,返回員工名字
delimiter $$
create procedure proc08(in empno int ,out out_ename varchar(50) )
begin
select ename into out_ename from emp where emp.empno = empno;
end $$
delimiter ;
call proc08(1001, @o_ename);
select @o_ename;

輸出的時候,需要在存儲方法中指定,并@變量名,最后才能讓這個變量接收到數(shù)值

其次輸出參數(shù)的定義的時候,也和輸入?yún)?shù)一樣的,out 參數(shù)名 類型(長度)

-- 封裝有參數(shù)的存儲過程,傳入員工編號,返回員工名字和薪資
delimiter $$
create procedure proc09(in empno int ,out out_ename varchar(50) ,out out_sal decimal(7,2))
begin
select ename,sal into out_ename,out_sal from emp where emp.empno = empno;
end $$
delimiter ;
call proc09(1001, @o_dname,@o_sal);
select @o_dname;
select @o_sal;

內部接收的時候就需要使用 into 變量名,變量名……

注意:也就是說,在存儲過程中使用out聲明輸出參數(shù),在內部視圖into 進行賦值之后,最后在調用存儲的時候需要在里面自定義一個變量進行接收 但是必須要 使用@變量名

修改傳入?yún)?shù)值

inout 表示從外部傳入的參數(shù)經過修改后可以返回的變量,既可以使用傳入變量的值也可以修改變量的值(即使函數(shù)執(zhí)行完)

-- 傳入員工名,拼接部門號,傳入薪資,求出年薪
delimiter $$
create procedure proc10(inout inout_ename varchar(50),inout inout_sal int)
begin
select concat(deptno,"_",inout_ename) into inout_ename from emp where ename = inout_ename;
set inout_sal = inout_sal * 12;
end $$
delimiter ;
set @inout_ename = '關羽';
set @inout_sal = 3000;
call proc10(@inout_ename, @inout_sal) ;
select @inout_ename ;
select @inout_sal ;

相對于,如果我們使用inout關鍵詞,這個參數(shù)可以作為輸入?yún)?shù),也可以作為輸出參數(shù),輸出參數(shù)時候,可以在內部的語句進行修改,然后覆蓋原來的值,最后調用的時候可以定義一樣的變量名,也可以不一樣。

  • in 輸入?yún)?shù),意思說你的參數(shù)要傳到存過過程的過程里面去,在存儲過程中修改該參數(shù)的值不能被返回
  • out 輸出參數(shù):該值可在存儲過程內部被改變,并向外輸出
  • inout 輸入輸出參數(shù),既能輸入一個值又能傳出來一個值)

到此這篇關于MySQL存儲過程輸入?yún)?shù)(in),輸出參數(shù)(out),輸入輸出參數(shù)(inout)的文章就介紹到這了,更多相關MySQL存儲過程輸入輸出內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • mysql全文搜索 sql命令的寫法

    mysql全文搜索 sql命令的寫法

    首先,大家先去下載一份dvbbs.php beta1的代碼,解壓后先拋開php代碼,找出你的mysql手冊,如果沒有手冊那么就直接看下面的實例操作吧!
    2011-01-01
  • mysql5.7.18解壓版啟動mysql服務

    mysql5.7.18解壓版啟動mysql服務

    這篇文章主要為大家詳細介紹了mysql5.7.18解壓版啟動mysql服務的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • mysql中varchar類型的日期進行比較、排序等操作的實現(xiàn)

    mysql中varchar類型的日期進行比較、排序等操作的實現(xiàn)

    在mysql使用過程中,日期一般都是以datetime、timestamp等格式進行存儲的,但有時會因為特殊的需求或歷史原因,日期的存儲格式是varchar,那么應該怎么進行比較和排序等問題,本文就來介紹一下
    2021-11-11
  • 你可能有所不知的MySQL正則表達式總結

    你可能有所不知的MySQL正則表達式總結

    使用正則表達式可以檢索或替換符合某個模式的文本內容,根據(jù)指定的匹配模式匹配文本中符合要求的特殊字符串,下面這篇文章主要給大家介紹了關于MySQL正則表達式的相關資料,需要的朋友可以參考下
    2023-05-05
  • Mysql?using?用法示例詳解

    Mysql?using?用法示例詳解

    這篇文章主要介紹了Mysql?using?用法示例代碼詳解,本文通過三種方法給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • MySQL分區(qū)之指定各分區(qū)路徑詳解

    MySQL分區(qū)之指定各分區(qū)路徑詳解

    mysql分區(qū)后每個分區(qū)成了獨立的文件,雖然從邏輯上還是一張表其實已經分成了多張獨立的表,下面這篇文章主要給大家介紹了關于MySQL分區(qū)之指定各分區(qū)路徑的相關資料,需要的朋友可以參考下
    2022-04-04
  • MySQL如何快速導入數(shù)據(jù)

    MySQL如何快速導入數(shù)據(jù)

    這篇文章主要介紹了MySQL如何快速導入數(shù)據(jù),幫助大家更好的理解和學習MySQL,感興趣的朋友可以了解下
    2020-08-08
  • MySQL與SQL的觸發(fā)器的不同寫法

    MySQL與SQL的觸發(fā)器的不同寫法

    當在SQL、MySQL數(shù)據(jù)庫中一張表中插入一條記錄時,觸動觸發(fā)器,使同一數(shù)據(jù)庫的另一張表插入相同記錄。
    2010-09-09
  • mysql5.7單實例自啟動服務配置過程

    mysql5.7單實例自啟動服務配置過程

    這篇文章主要介紹了mysql5.7單實例自啟動服務配置的過程,附含配置源碼,有需要的朋友可以借鑒參考下,希望可以有所幫助,感謝閱讀
    2021-09-09
  • MySQL中二進制與重做日志文件的基本概念學習教程

    MySQL中二進制與重做日志文件的基本概念學習教程

    這篇文章主要介紹了MySQL中二進制日志文件與重做日志文件的基本概念學習教程,講到了一些重做日志與二進制日志的區(qū)別,需要的朋友可以參考下
    2015-11-11

最新評論