mysql 過程和函數_MySQL:存儲過程和函數

變量

系統變量

變量由系統提供,不是用戶自定義的,屬于服務器層面

全局變量

會話變量

# 如果是全局級別,則需要加global,如果是會話級別,則需要加session,如果不寫,則默認是會話

# 查看全局變量

SHOW GLOBAL VARIABLES;

SHOW GLOBAL VARIABLESLIKE "%char%";

# 查看會話變量

SHOW SESSION VARIABLES; # 默認是會話變量

SHOW SESSION VARIABLESLIKE "%char%";

# 查看指定的某個系統變量的值SELECT @@系統變量名; # 默認查看的是會話變量SELECT @@GLOBAL.系統變量名;

# 為系統變量賦值SET global|[session] 系統變量名=值; # 默認是會話變量SET @@global|[session].系統變量名=值; # 默認是會話變量

自定義變量

用戶自定義的變量

用戶變量:針對于當前會話連接有效,同于會話變量的作用域

# 申明并初始化SET @用戶變量名=值;SET @用戶變量名:=值;SELECT @用戶變量名:=值;

# 賦值或更新用戶變量的值SET @用戶變量名=值;SET @用戶變量名:=值;SELECT @用戶變量名:=值;SELECT 字段 INTO 變量名 FROM表SELECT COUNT(*) INTO @count1 FROMstudent;

# 查看用戶變量名SELECT @用戶變量名;

局部變量:僅僅在begin end中有效,應用在begin end的第一句話

# 聲明DECLARE變量名 類型;DECLARE 變量名 類型 DEFAULT值;

# 賦值SET 局部變量名=值SET 局部變量名:=值SELECT @局部變量名:=值SELECT 字段 INTO @局部變量名 FROM表;

#查看SELECT 局部變量名

局部變量和用戶變量

用戶變量:? 當前會話? ? ? ? ? ? ? ?會話的任何地方定義和使用 ? ? ? ? ? ? ? ?  必須加@符號,不用限定類型

局部變量:? BEGIN? END中? ? ?只能在BEGIN END中,且為第一句話? ? ? ?一般不加@符號,需要限定類型

存儲過程

介紹

一組預先編譯好的SQL語句的集合,理解成批處理語句

提高代碼的重用性

簡化操作

減少了編譯次數,并且減少了和數據庫服務器的連接次數,提高了效率

創建

CREATE PROCEDURE存儲過程名(參數列表)BEGIN存儲過程體(一組合法的SQL語句)END

注意:

參數列表包含三個部分 參數模式? 參數名? 參數類型

如果存儲過程體僅僅只有一條語句,BEGIN END可以省略

存儲過程體中的每條SQL語句的結尾必須要加分號

存儲過程的結尾可以使用DELIMITER重新設置

參數模式:

IN: 該參數可以作為輸入,也就是該參數需要調用方法傳入值

OUT: 該參數可以作為輸出,也就是該參數可以作為返回值

INOUT: 既可以作為輸入也可以作為輸出,既要傳入值,也可以返回值

調用

CALL 存儲過程名(實參列表);

案例

/*1. 空參列表

案例1: 插入到admin表中五條記錄

DELIMITER $

CREATE PROCEDURE myp1()

BEGIN

INSERT INTO admin(name, `password`)

VALUES('jhon1', "000"),('jhon2',"001");

END $

CALL myp1()$

SELECT * FROM admin$

2. IN模式參數, 默認是IN

案例: 創建存儲過程實現 根據girl name 查詢對應的boy信息

CREATE PROCEDURE myp2(IN g_name VARCHAR(20) )

BEGIN

SELECT b.* FROM boys b RIGHT JOIN girls g ON b.id=g.boy_id WHERE g.name=g_name;

END $

CALL myp2('Mary')$

案例: 創建存儲過程實現,用戶是否登入成功

CREATE PROCEDURE myp3(IN name VARCHAR(20), in PASSWORD VARCHAR(20))

BEGIN

DECLARE res INT DEFAULT '';

select count(*) into res from admin where admin.name=name and admin.password=PASSWORD;

SELECT IF(res>0,'successfule','failed');

END $

CALL myp3('root','123')$

3. OUT模式的存儲過程

案例: 根據girl name ,返回boy name

CREATE PROCEDURE myp5(IN girl_nam VARCHAR(20), OUT boy_name VARCHAR(20), OUT age INT)

BEGIN

SELECT b.name,b.age INTO boy_name,age FROM boys b INNER JOIN girls g ON b.id=g.boy_id WHERE g.name=girl_name;

END $

CALL myp5('Mary', @bname, @age)$

SELECT @banme,@age$

4. INOUT 模式參數

案例: 傳入a和b兩個值。最終a和b都翻倍并返回

CREATE PROCEDURE myp6(INOUT a INT, INOUT b INT)

BEGIN

SET a=a*2;

SET b=b*2;

END $

SET @a=20$

SET @b=20$

CALL myp6(@a,@b)$

SELECT @a,@b$

*

刪除存儲過程

DROP PROCEDURE 存儲過程名

查看存儲過程

SHOW CREATE PROCEDURE 存儲過程名

函數

介紹

一組預先編譯好的SQL語句的集合,理解成批處理語句

提高代碼的重用性

簡化操作

減少了編譯次數,并且減少了和數據庫服務器的連接次數,提高了效率

對比存儲

存儲過程: 可以有0或多個返回, 適合做批量插入、批量更新

函數? ? ? ?:? 有且僅有一個返回,適合做處理數據后返回一個結果

創建

CREATE FUNCTION函數名(參數列表) RETURNS返回類型BEGIN函數體END

注意:

參數列表包含兩部分: 參數名? 參數類型

函數體必須有return語句:? return 值

函數體僅有一句話時,可以省略begin end

使用delimiter語句設置結束標記

調用

SELECT 函數名(參數列表)

案例

/*1. 無參數返回

案例: 返回員工個數

DELIMITER $

CREATE FUNCTION myf1 RETURNS INT

BEGIN

DECLARE c INT DEFAULT 0;

SELECT COUNT(*) INTO c FROM employees;

RETURN c;

END $

SELECT myf1()$

2. 有參數返回

案例: 根據員工名,返回他的工資

CREATE FUNCTION(name VARCHAR(20)) RETURNS DOUBLE

BEGIN

SET @sal=0;

SELECT salary INTO @sal FROM employees e WHERE e.name =name;

RETURN @sal;

END

SELECT myf2('jhon')$*/

查看函數

SHOW CREATE FUNCTION 函數名

刪除函數

DROP FUNCTION 函數名;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531776.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531776.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531776.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

python修改服務器ip,[python+Bat]讀表修改機房IP

[Shell] 純文本查看 復制代碼拷貝一下腳本到.bat文件,雙擊運行即可,有交互式提示輸入新的計算機名 ECHO OFFcolor 0AECHO ----------------------------------------------------------------------------ECHO.ECHO 版權所有 copyright of ECHO.ECHO ~~~…

hdu 1811Rank of Tetris (并查集 + 拓撲排序)

1 /*2 題意&#xff1a;這些信息可能有三種情況&#xff0c;分別是"A > B","A B","A < B"&#xff0c;分別表示A的Rating高于B,等于B,小于B。3 4 現在Lele并不是讓你來幫他制作這個高手榜&#xff0c;他只是想知道&#xff0c;根據這…

ambari mysql jar_從零開始安裝 Ambari (3) -- 安裝 Ambari

1. 安裝yum -y install ambari-server2. ambari server 需要一個數據庫存儲元數據&#xff0c;默認使用的 Postgres 數據庫。默認的用戶名和密碼是&#xff1a; ambari/bigdata 。但是一般情況下&#xff0c;后面還要安裝 hive 和 Ranger&#xff0c;也需要一個存元數據的數據庫…

服務器2012系統在dos卸載,Windows系統下徹底刪除Windows.old 文件夾的方法

系統是直接硬盤安裝的&#xff0c;導致c盤產生了舊系統的文件夾Windows.old&#xff0c;占用很大的磁盤空間&#xff0c;刪也刪不掉&#xff0c;咋辦&#xff1f;不要緊&#xff0c;下面大神來教你神操作&#xff01;&#xff01;&#xff01;1、打開“計算機”&#xff0c;選擇…

hdu3635 Dragon Balls(帶權并查集)

1 /*2 題意&#xff1a;有N個城市&#xff0c; 每一個城市都有一個龍珠&#xff08;編號與城市的編號相同&#xff09;&#xff0c;有兩個操作3 T A ,B 將標號為A龍珠所在城市的所有的龍珠移動到B龍珠所在城市中&#xff01; 4 5 思路&#xff1a;并查集 &#xff…

backupexec mysql_MySQL備份可能遇到的坑

MySQL備份工具&#xff0c;支持各種參數選項&#xff0c;使用不同的選項極有可能影響備份處理過程。本文使用我們常規認為合理的備份參數&#xff0c;測試/驗證是否存在容易忽視的坑# 常規備份參數# mysqldumpshell> mysqldump --single-transaction --master-data2 -B repl…

win10虛擬機服務器錯誤怎么解決方法,虛擬機下安裝win10系統后出現升級報錯故障的解決方法【圖文】...

現在的win10還是很挑系統的&#xff0c;兼容性有待進一步增強。有些在虛擬機環境下安裝了win10的小伙伴&#xff0c;升級是很可能報以下錯誤的&#xff0c;升級你的ESX版本吧&#xff0c;5.5以下升級win10基本都是沒戲的。VM workstation11以上是明確支持win10。不能升級win10怎…

hdu1962Corporative Network帶權回路

1 /*2 有N個企業&#xff0c;每個企業想要實現通信&#xff0c;要用線路來連接&#xff0c;線路的長度為abs(a-b)%1000;3 如果企業a 鏈接到了企業b 那么b就是the center of the serving!4 然后有兩種操作&#xff1a;5 E a &#xff1a; 輸出企業a到serving ce…

mysql客戶端修改sqlmode_MySQL修改sql_mode

一 ERR 1067引發的血案今天在Navicat中運行sql語句創建數據表出現了錯誤Err 1067。而這條語句在有些同事的mysql上是正確的&#xff0c;但是在有些人那里就報錯。QQ截圖20170811143551.png原因竟然是timestamp的默認值不正確。查閱資料得知&#xff0c;mysql5.7版本中有了一個S…

零基礎mysql項目實例_MySQL-零基礎開發

1.終端下連接mysql服務mysql -uroot -p回車后輸入設定的密碼即可。進去后每條命令結尾要帶分號&#xff1b;退出命令exit單行注釋有兩種&#xff1a;#  或 --空格。多行注釋/*  */2.基本命令集合針對數據庫&#xff1a;use sys;  show databases;查看當前操作的數據庫&a…

hdu2066一個人的旅行(多源點多匯點的最短路徑問題)

&#xff0f;&#xff0a;思路&#xff1a;多源點&#xff0c;多會點的最短路徑&#xff01;將最小號&#xff0d;&#xff11;的節點但最源點&#xff0c;將最大號&#xff0b;&#xff11;的點當作匯點&#xff01;將問題轉變成從一個源點到一個匯點的最短路徑的問題&#xf…

php設置mysql 編碼_php怎么設置mysql編碼?

在php中&#xff0c;可以使用mysql_query()函數來設置mysql編碼&#xff0c;語法“mysql_query(SET NAMES 編碼方式);”&#xff1b;mysql_query()函數需要放置在mysql_connect()語句之后。在php中&#xff0c;可以使用mysql_query()函數來設置mysql編碼。在PHP連接數據庫的時候…

nyoj 925 國王的煩惱(最小生成樹)

1 /*2 題意&#xff1a;N個城市中每兩個城市有多條路徑連接&#xff0c;可是因為路徑存在的天數是有限的&#xff01;以為某條路經不存在了3 導致N個城市不能連通了&#xff0c;那么村名們就會抗議&#xff01;問一共會有多少次抗議&#xff01;4 5 思路&#…

golang 切片 接口_Go編程模式:切片,接口,時間和性能

在本篇文章中&#xff0c;我會對 Go 語言編程模式的一些基本技術和要點&#xff0c;這樣可以讓你更容易掌握 Go 語言編程。其中&#xff0c;主要包括&#xff0c;數組切片的一些小坑&#xff0c;還有接口編程&#xff0c;以及時間和程序運行性能相關的話題。本文是全系列中第 1…

poj 3352Road Construction(無向雙連通分量的分解)

1 /*2 題意&#xff1a;給定一個連通的無向圖G&#xff0c;至少要添加幾條邊&#xff0c;才能使其變為強連通圖&#xff08;指的是邊強聯通&#xff09;。 3 思路&#xff1a;利用tarjan算法找出所有的雙聯通分量&#xff01;然后根據low[]值的不同將雙聯通分量4 進行…

jsp中去掉超鏈接下劃線嗎_網頁中如何去掉超鏈接的下劃線

展開全部a:link {text-decoration: none;}a:visited {text-decoration: none;color: #6B6C70;}其中的text-decoration: none;是消除下劃線例如&#xff1a;只需加入一段代碼32313133353236313431303231363533e59b9ee7ad9431333337393534&#xff1a;td,body { font-size: 9pt}a…

POJ 2312Battle City(BFS-priority_queue 或者是建圖spfa)

1 /*2 bfs搜索&#xff01;要注意的是點與點的權值是不一樣的哦&#xff01;3 空地到空地的步數是1&#xff0c; 空地到墻的步數是2&#xff08;轟一炮移過去&#xff09;4 所以用到優先隊列進行對當前節點步數的更新&#xff01; 5 */6 #include<iostream>7 #…

linux訓練python出現killed_Linux 查看進程被殺死的詳情

運行寫的不太完善的爬蟲程序, 未限制任務隊列大小, 再加上本子配置不高, 爬取網站到第3層大半時, 內存不足了...進程運行太猛, 導致系統 out of memory, 那么此進程被系統的oom killer殺死.此時終端顯示 "Killed" 或 "已殺死".查看相關信息的命令:dmesg | …

mysql 123456_MySQL字符串中抽取數值的方法 select -(-'123456@163.com'); 很牛逼

MySQL的字符串函數非常多&#xff0c;以至于有時候我不知道該如何靈活的使用這些函數。字符串基本信息函數 collation convert&#xff0c;char_length等加密函數 password(x)&#xff0c;encode, aes_encrypt字符串連接函數 concat(x1,x2,….)修剪函數 trim,ltrim,…

ZZUOJ 1199 大小關系(拓撲排序,兩種方法_判斷入度和dfs回路判斷)

1 /*2 這道題如果按照度為0的節點來判斷的時候,將度為0的節點和其相連的節點&#xff08;度數并減去1&#xff09; 3 從圖中去掉&#xff0c;如果度為0的節點的個數為0個但是圖中的節點沒有都去掉的 時候那么說明4 出現了回路!用這種方法必須將重邊去除掉&#xff01; …