亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL 聲明變量及存儲過程分析

 更新時間:2017年10月09日 16:34:55   作者:吾輩丶何以為戰(zhàn)  
這篇文章主要介紹了MySQL 聲明變量及存儲過程的相關(guān)內(nèi)容,小編覺得挺不錯的,這里分享給大家,需要的朋友可以參考下。

聲明變量

設(shè)置全局變量

set @a='一個新變量';

在函數(shù)和儲存過程中使用的變量declear

declear a int unsigned default 1;

這種變量需要設(shè)置變量類型 而且只存在在 begin..end 這段之內(nèi)

select .. into..  直接將表內(nèi)內(nèi)容賦值到指定變量當(dāng)中

select name,bid into @a,@b from bank limit 1;

要注意一點就是變量名不能和字段名一致

存儲過程

存儲過程將一段通用的操作封裝在一起 這樣再不同平臺都可以公用了

儲存過程沒有返回值,而且不能sql語句調(diào)用,只能是call調(diào)用,而且不返回結(jié)果集,執(zhí)行就執(zhí)行了

要注意的是在儲存過程中進行sql語句要用到 ; 這個系統(tǒng)默認結(jié)束符 要重新設(shè)置成別的,不然在寫過程的一半系統(tǒng)就錯認程序為終止繼而報錯

改變結(jié)束命令符為$

delimiter$+回車 或者簡寫成 \d $+回車

顯示所有存儲過程

show procedure status;

刪除指定存儲過程

drop procedure 過程名;

存儲過程演示'

\d $ 1 create procedure yanshi(in arg tinyint)
begin
declare age tinyint default 0;
set age=arg;
if age<20 then
select '小于20的數(shù)';
elseif age>20 then
select '大于20的數(shù)';
end if;
end
$
//調(diào)用過程
set @num=12$
call yanshi(@num)$
call yanshi(21)$

判斷輸入到存儲過程中的數(shù)字屬于哪個階段

在存儲過程中傳參分 in ,out , inout 三種

in 可以輸出從外部傳入的變量 不會改變傳進變量本來的值

create procedure a(in id int)
begin
  select id;
  set id = 100;
end
$
set @id=1$
call a(@id)$ //輸出1 即從外部傳進來的@id 的值
select $id$ //輸出1 說明存儲過程中沒有改變傳進的值

out 不能輸出從外部傳進的值  會改變傳進變量本來的值

create procedure b(out id int)
begin
  select id;
  set id = 100;
end
$
set @id=1$
call b(@id)$  //輸入null
select @id$ //輸出100

inout 就是又能輸出傳入變量又能改變傳入變量咯

下面是檢驗?zāi)汶娔X硬件性能的時候了

還記得當(dāng)年的bank表嗎? 就是他保留住 然后執(zhí)行以下命令:

create procedure addbank()
begin
  declare i int default 0;
  set i = 5000000;
  while i > 0 do
  insert into bank (name) values (i);
  set i = i - 1;
  end while;
end
$
call addbank()$

祝你好運

總結(jié)

以上就是本文關(guān)于MySQL 聲明變量及存儲過程分析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以參閱:幾個比較重要的MySQL變量  MySQL prepare原理詳解  ORACLE SQL語句優(yōu)化技術(shù)要點解析等,有什么問題可以隨時留言,小編會及時回復(fù)大家的。感謝朋友們對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • MySQL無法修改主鍵的問題分析及解決方案

    MySQL無法修改主鍵的問題分析及解決方案

    最近同事咨詢了一個問題,TDSQL(for MySQL)中的某張表主鍵需要改為聯(lián)合主鍵,是否必須先刪除現(xiàn)有的主鍵?因為刪除主鍵時,提示這個錯誤,所以本文給大家介紹了MySQL無法修改主鍵的問題分析及解決方案,需要的朋友可以參考下
    2024-01-01
  • MySQL數(shù)據(jù)類型DECIMAL用法詳解

    MySQL數(shù)據(jù)類型DECIMAL用法詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)類型DECIMAL用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句

    mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句

    mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句,需要的朋友可以參考下。
    2011-05-05
  • MySQL基于索引的壓力測試的實現(xiàn)

    MySQL基于索引的壓力測試的實現(xiàn)

    本文主要介紹了MySQL基于索引的壓力測試的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • MySQL數(shù)據(jù)庫安全之防止撰改的方法

    MySQL數(shù)據(jù)庫安全之防止撰改的方法

    這篇文章主要介紹了MySQL數(shù)據(jù)庫防止撰改的方法,需要的朋友可以參考下
    2014-07-07
  • MariaDB(Mysql分支)my.cnf配置文件中文注釋版

    MariaDB(Mysql分支)my.cnf配置文件中文注釋版

    這篇文章主要介紹了MariaDB my.cnf配置文件中文注釋版,MariaDB是Mysql的一個分支,完全兼容Mysql,需要的朋友可以參考下
    2014-06-06
  • mysql獲得60天前unix時間的方法

    mysql獲得60天前unix時間的方法

    首先根據(jù)now()獲得當(dāng)前時間,使用adddate()方法獲得60天前時間,使用unix_timestamp()方法轉(zhuǎn)換時間類型,需要的朋友可以參考下
    2014-09-09
  • mysql 8.0.22 下載安裝配置方法圖文教程

    mysql 8.0.22 下載安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.22 下載安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Ubuntu Server 16.04下mysql8.0安裝配置圖文教程

    Ubuntu Server 16.04下mysql8.0安裝配置圖文教程

    這篇文章主要為大家詳細介紹了Ubuntu Server 16.04下mysql8.0安裝配置圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 關(guān)于JDBC與MySQL臨時表空間的深入解析

    關(guān)于JDBC與MySQL臨時表空間的深入解析

    這篇文章主要給大家介紹了關(guān)于JDBC與MySQL臨時表空間的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09

最新評論