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

Mysql中的存儲過程超詳細講解

 更新時間:2025年04月25日 09:51:35   作者:貓咪-9527  
這篇文章主要介紹了Mysql中的存儲過程超詳細講解,包括存儲過程基本語法,感興趣的朋友一起看看吧

1. 視圖

視圖是一個虛擬表,其內容由查詢定義。與實際的物理表類似,視圖也包含一系列具有名稱的列和行數據。視圖的數據變化會影響基表,反之,基表的數據變化也會影響視圖。

1.1 基本使用

創(chuàng)建視圖

創(chuàng)建視圖的基本語法如下:

CREATE VIEW 視圖名 AS SELECT 查詢語句;

示例:查看學生的學號、姓名、成績和課程號:

SELECT s1.sno, snme, sdept, grade, cno 
FROM student s1 
JOIN score s2 ON s1.sno = s2.sno;

創(chuàng)建視圖 v_s_s,該視圖包含學生學號、姓名、成績和課程號:

CREATE VIEW v_s_s AS 
SELECT s1.sno, snme, sdept, grade, cno 
FROM student s1 
JOIN score s2 ON s1.sno = s2.sno;

修改視圖中的數據:假設我們希望修改馬小燕課程號 001 的成績?yōu)?100,若視圖支持更新操作,可以修改原表數據:

UPDATE v_s_s 
SET grade = 100 
WHERE sno = '馬小燕' AND cno = '001';

刪除視圖

刪除視圖的語法如下:

DROP VIEW 視圖名;

1.2 視圖的規(guī)則與限制

視圖與基表之間存在緊密的關系,視圖數據的修改會影響基表的數據,反之亦然。為了確保系統(tǒng)的穩(wěn)定性,使用視圖時需要特別注意以下限制:

  • 數據更新限制:并非所有視圖都支持數據更新操作。特別是當視圖涉及多個表的連接、聚合函數、分組(GROUP BY)等操作時,修改視圖中的數據可能會受到限制。例如,包含聚合函數或聯(lián)合查詢的視圖通常不支持更新。
  • 性能考慮:雖然視圖可以簡化查詢,但如果查詢的視圖非常復雜且涉及大量數據,可能會導致性能問題。因此,在設計視圖時應避免過于復雜的查詢,特別是涉及大量數據的視圖。
  • 不支持索引:視圖本身不支持索引,因此在使用視圖時,查詢性能可能不如直接查詢基表。如果視圖查詢包含復雜的計算或連接操作,可能會對查詢性能產生影響。
  • 只讀視圖:一些視圖被設計為只讀的,無法修改其中的數據。這通常發(fā)生在視圖涉及多表連接、聚合操作或復雜計算時。對于這種只讀視圖,修改視圖中的數據將會失敗。

1.3 視圖與查找數據創(chuàng)建表的比較

視圖和基于查詢結果創(chuàng)建的表在以下方面有所不同:

視圖
視圖是動態(tài)的,它始終基于最新的查詢結果。當視圖中的數據發(fā)生變化時,實際的數據表也會發(fā)生變化。視圖不存儲數據本身,而是存儲查詢邏輯。當查詢視圖時,實際上是執(zhí)行視圖定義中的查詢語句。

語法示例:

CREATE VIEW t_name AS SELECT 查詢數據;

創(chuàng)建表

使用 CREATE TABLE 可以將查詢結果保存為一個物理表。與視圖不同,創(chuàng)建的表會將數據永久存儲在數據庫中,數據修改不會影響原始數據表。創(chuàng)建的表可以具有索引等性能優(yōu)化。

語法示例:

CREATE TABLE t_name AS SELECT 查詢數據;

1.4 視圖添加限制

在 MySQL 中,視圖雖然提供了極大的便利,但在某些情況下需要對其進行適當的限制,以確保數據的一致性和完整性。以下是常見的視圖限制及其應用:

視圖的修改限制

  • 當視圖涉及多個表、聚合函數、分組等操作時,視圖通常為只讀,無法直接修改。只有在視圖基于單一表且沒有涉及復雜計算時,視圖才通常支持數據更新操作。
  • 若需要限制視圖中數據的修改,可以使用 WITH CHECK OPTION,該選項確保通過視圖進行的更新操作符合視圖中的條件,否則修改會被拒絕。

例如,創(chuàng)建一個只允許修改 grade >= 60 的視圖:

CREATE VIEW v_students AS 
SELECT sno, snme, grade 
FROM student 
WHERE grade >= 60
WITH CHECK OPTION;

視圖查詢限制

視圖能夠簡化復雜的查詢,但也需要根據實際需求進行適當限制。為了確保不暴露敏感數據,可以設計只包含非敏感字段或經過加密/脫敏處理的視圖。

權限控制與安全性

權限設置示例:

GRANT SELECT ON v_employee_view TO 'user1';

使用視圖時,應當考慮權限控制,通過為不同用戶分配不同的視圖訪問權限,可以確保數據安全。視圖可以提供一個中介層,使得用戶僅能訪問特定數據,而不暴露整個表的數據。

對于敏感數據,視圖的設計應遵循最小權限原則,避免直接暴露敏感信息。

2. 存儲過程的基本語法

存儲過程是一組 SQL 語句的集合,它被存儲在數據庫中,并可根據需要執(zhí)行,可以接收輸入參數并返回結果。

2.1 創(chuàng)建存儲過程

存儲過程的創(chuàng)建需要修改語句分隔符,以避免與 SQL 語句的結束符(;)發(fā)生沖突:

DELIMITER $$  -- 修改分隔符以避免與語句結束符沖突
CREATE PROCEDURE procedure_name (parameters)
BEGIN
   -- SQL 語句
END$$
DELIMITER ;  -- 恢復分隔符

存儲過程的參數包括:

  • IN:輸入參數,用于向存儲過程傳遞值。
  • OUT:輸出參數,用于存儲過程返回數據。
  • INOUT:輸入輸出參數,既可以接收輸入數據,又可以返回結果。

不改變分隔符會出現報錯:

圖一

2.2 調用存儲過程

調用存儲過程的語法如下:

CALL procedure_name(parameters);

2.3 查看存儲過程信息

查看所有數據庫的存儲過程:

SHOW PROCEDURE STATUS;

查看當前數據庫的存儲過程:

SHOW PROCEDURE STATUS WHERE db = 'db_name';

Db:存儲過程所在的數據庫

Name:存儲過程的名稱

Type:存儲過程類型(例如 PROCEDURE

Definer:存儲過程的定義者

Modified:最后修改時間

Created:創(chuàng)建時間

Security_type:安全類型

Comment:存儲過程的注釋

2.4 查看存儲過程定義

查看存儲過程定義的語法:

SHOW CREATE PROCEDURE procedure_name;

2.5 刪除存儲過程

刪除存儲過程的語法如下:

DROP PROCEDURE procedure_name;

3. 變量

3.1 查看系統(tǒng)變量

 3.1.1查看所有系統(tǒng)變量

 查看當前會話的系統(tǒng)變量:

SHOW SESSION VARIABLES;

 查看全局系統(tǒng)變量:

SHOW GLOBAL VARIABLES;

3.1.2系統(tǒng)變量的模糊匹配

show session variables like '...';
?show global variables like '...';

 3.1.3查看指定變量

select @@global.tname;----查看指定全局環(huán)境變量
select @@session.tname;----查看當前會話環(huán)境變量

3.2 設置全局變量與會話變量

Aspect

全局隔離權限

會話隔離權限

作用范圍

系統(tǒng)范圍,決定了系統(tǒng)的默認行為和限制

僅對當前會話有效,獨立于全局權限

初始化與導入

在系統(tǒng)初始化時從全局設置導入

在新會話啟動時從全局導入配置

修改的時效性

修改后不會立即影響現有會話,需重新啟動會話才會生效

當前會話的隔離級別修改不會影響其他會話

對系統(tǒng)設計的影響

確保系統(tǒng)權限的統(tǒng)一性,易于集中管理

確保每個會話可以根據需要調整權限,而不影響其他會話

3.2.1全局變量設置

SET GLOBAL transaction_isolation_level = 'READ COMMITTED';

 重新啟動一個新的會話:

3.2.2當前會話變量設置

set session transaction isolation level read committed;

重新啟動一個會話:

3.3 用戶定義變量

用戶定義變量是會話級別的臨時變量,用戶可以在 SQL 語句中使用它們來存儲數據或進行計算。變量名以 @ 開頭。例如:

 使用 SET 語句定義變量:

SET @variable_name = value;-----方法一
SET @variable_name := value;----方法二

例如,定義一個名為 @age 的變量并賦值為 25:

SET @age = 25;

也可以直接在查詢語句中進行賦值:

SELECT @variable_name := expression;

例如,將查詢結果賦值給變量:

SELECT @age := age FROM users WHERE name = 'John';-----方法一
SELECT age into @age FROM users WHERE name = 'John';---方法二

3.4 局部變量

局部變量是在存儲過程、函數或觸發(fā)器內部定義的變量,作用范圍僅限于該存儲過程、函數或觸發(fā)器的執(zhí)行期間。它們通常用于臨時存儲數據、進行計算或傳遞信息。

3.4.1 局部變量的聲明

在 MySQL 中,局部變量通過 DECLARE 語句在存儲過程、函數或觸發(fā)器中聲明。局部變量的作用范圍僅限于聲明它們的存儲過程、函數或觸發(fā)器內部,并且不能在 SQL 查詢的其他地方使用。

局部變量的特點:

  • 局部性:局部變量僅在存儲過程、函數或觸發(fā)器的執(zhí)行期間有效。當存儲過程或函數執(zhí)行完畢后,局部變量會被自動銷毀。
  • 無法在查詢外部使用:局部變量只能在其所在的存儲過程、函數或觸發(fā)器內使用,不能在 SQL 查詢的其他部分引用。
  • 生命周期:當存儲過程或函數執(zhí)行結束時,局部變量的值會丟失。每次執(zhí)行存儲過程或函數時,局部變量會重新創(chuàng)建,并可以為其賦予初始值(如果指定了初始值)。

3.4.2 局部變量的使用

局部變量常用于存儲中間計算結果、執(zhí)行邏輯運算或在存儲過程/函數中臨時存儲查詢結果。它們的使用受到以下限制:

  • 聲明位置DECLARE 語句必須在存儲過程、函數或觸發(fā)器的開頭部分,也就是在 BEGIN 語句之前聲明。
  • 命名規(guī)則:局部變量不能使用以 @ 開頭的命名方式。@ 是用于用戶定義會話變量的前綴,局部變量不允許使用此命名規(guī)則。
  • 初始值:如果沒有為局部變量指定初始值,則其默認值為 NULL。因此,在使用局部變量時,開發(fā)者需要考慮 NULL 的處理,確保程序的邏輯正確。

 語法:

  • DECLARE variable_name data_type [DEFAULT value];

variable_name:變量的名稱。

data_type:變量的數據類型(如 INT, VARCHAR, DATE 等)。

[DEFAULT value]:可選,設置默認值。如果不指定,則默認值為 NULL。

例子:

DECLARE @user_id INT DEFAULT 100;
DECLARE @user_name VARCHAR(255) DEFAULT 'John';

到此這篇關于Mysql之存儲過程的文章就介紹到這了,更多相關mysql存儲過程內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Mysql中幾種插入效率的實例對比

    Mysql中幾種插入效率的實例對比

    這篇文章通過實例跟大家介紹了Mysql中幾種插入方法的效率對比,這其中包括逐條插入、基于事務的批量插入、單條語句一次插入多組數據以及導入數據文件等四種方法的對比,文中通過實例代碼介紹很詳細,需要的朋友們下來來一起看看吧。
    2017-04-04
  • django2.2版本連接mysql數據庫的方法

    django2.2版本連接mysql數據庫的方法

    這篇文章主要介紹了django2.2版本如何連接mysql數據庫,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • 一文帶你了解Mysql主從同步原理

    一文帶你了解Mysql主從同步原理

    本文主要講解了Mysql主從同步原理,主從同步可以擴展數據庫的負載能力、容錯還可以數據備份等。想要了解相關內容的朋友可以閱讀這篇文章
    2021-08-08
  • MySQL 主從復制原理與實踐詳解

    MySQL 主從復制原理與實踐詳解

    這篇文章主要介紹了MySQL 主從復制原理與實踐,結合實例形式分析了MySQL 主從復制基本概念、原理、實現方法與相關注意事項,需要的朋友可以參考下
    2020-05-05
  • 詳解MySQL監(jiān)控工具 mysql-monitor

    詳解MySQL監(jiān)控工具 mysql-monitor

    這篇文章主要介紹了解MySQL監(jiān)控工具 mysql-monitor的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-07-07
  • MySQL InnoDB引擎ibdata文件損壞/刪除后使用frm和ibd文件恢復數據

    MySQL InnoDB引擎ibdata文件損壞/刪除后使用frm和ibd文件恢復數據

    mysql的ibdata文件被誤刪、被惡意修改,沒有從庫和備份數據的情況下的數據恢復,不能保證數據庫所有表數據的100%恢復,目的是盡可能多的恢復,下面是具體的操作方法
    2025-03-03
  • Windows下通過MySQL Installer安裝MySQL服務的教程圖解

    Windows下通過MySQL Installer安裝MySQL服務的教程圖解

    MYSQL官方提供了Installer方式安裝MYSQL服務以及其他組件,使的Windows下安裝,卸載,配置MYSQL變得特別簡單。接下來通過圖文并茂的形式給大家介紹Windows下通過MySQL Installer安裝MySQL服務的教程,一起看看吧
    2018-10-10
  • MySQL修改表結構操作命令總結

    MySQL修改表結構操作命令總結

    這篇文章主要介紹了MySQL修改表結構操作命令總結,包含如刪除列、添加列、修改列、添加主鍵、刪除主鍵、添加唯一索引、添加普通索引等內容,需要的朋友可以參考下
    2014-12-12
  • CentOS7使用rpm包安裝mysql 5.7.18

    CentOS7使用rpm包安裝mysql 5.7.18

    這篇文章主要為大家詳細介紹了CentOS7使用rpm包安裝mysql 5.7.18的相關步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • MySQL中數據查詢語句整理大全

    MySQL中數據查詢語句整理大全

    查詢語句是以后在工作中使用最多也是最復雜的用法,如何精準的查詢出想要的結果以及用最合理的邏輯去查詢尤為重要,下面這篇文章主要給大家介紹了關于MySQL中數據查詢語句的相關資料,需要的朋友可以參考下
    2023-04-04

最新評論