91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Mysql存儲過程中利用游標循環對臨時表進行讀取

發布時間:2020-12-14 14:09:48 來源:億速云 閱讀:310 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關怎么在Mysql存儲過程中利用游標循環對臨時表進行讀取,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

游標

游標(Cursor)是用于查看或者處理結果集中的數據的一種方法。游標提供了在結果集中一次一行或者多行前進或向后瀏覽數據的能力。

游標的使用方式

定義游標:Declare 游標名稱 CURSOR for table;(table也可以是select出來的結果集)
打開游標:Open 游標名稱;
從結果集獲取數據到變量:fetch 游標名稱 into field1,field2;
執行語句:執行需要處理數據的語句
關閉游標:Close 游標名稱;

BEGIN
  # 聲明自定義變量
  declare c_stgId int;
  declare c_stgName varchar(50);
  # 聲明游標結束變量
  declare done INT DEFAULT 0;

  # 聲明游標 cr 以及游標讀取到結果集最后的處理方式
  declare cr cursor for select Name,StgId from StgSummary limit 3;
  declare continue handler for not found set done = 1;

  # 打開游標
  open cr;

  # 循環
  readLoop:LOOP
    # 獲取游標中值并賦值給變量
    fetch cr into c_stgName,c_stgId;
    # 判斷游標是否到底,若到底則退出游標
    # 需要注意這個判斷
    IF done = 1 THEN
      LEAVE readLoop; 
    END IF; 
    
      SELECT c_stgName,c_stgId;
    
  END LOOP readLoop;
  -- 關閉游標
  close cr;
END

聲明變量Declare語句注意點:

  • Declare語句通常用來聲明本地變量、游標、條件或者handler

  • Declare語句只允許出現在BEGIN...END語句中而且必須出現在第一行

  • Declare的順序也有要求,通常是先聲明本地變量,再是游標,然后是條件和handler

自定義變量命名注意點:

自定義變量的名稱不要和游標的結果集字段名一樣。若相同會出現游標給變量賦值無效的情況。

臨時表

臨時表只在當前連接可見,當關閉連接時,Mysql會自動刪除表并釋放所有空間。因此在不同的連接中可以創建同名的臨時表,并且操作屬于本連接的臨時表。
與普通創建語句的區別就是使用 TEMPORARY 關鍵字

CREATE TEMPORARY TABLE StgSummary(
 Name VARCHAR(50) NOT NULL,
 StgId INT NOT NULL DEFAULT 0
);

臨時表使用限制

  1. 在同一個query語句中,只能查找一次臨時表。同樣在一個存儲過程中也不能多次查詢臨時表。但是不同的臨時表可以在一個query中使用。

  2. 不能用RENAME來重命名一個臨時表,但是可以用ALTER TABLE代替

ALTER TABLE orig_name RENAME new_name;
  • 臨時表使用完以后需要主動Drop掉

DROP TEMPORARY TABLE IF EXISTS StgTempTable;

存儲過程中使用游標循環讀取臨時表數據

BEGIN
## 創建臨時表
CREATE TEMPORARY TABLE if not exists StgSummary(
 Name VARCHAR(50) NOT NULL,
 StgId INT NOT NULL DEFAULT 0
);
TRUNCATE TABLE StgSummary;

## 新增臨時表數據
INSERT INTO StgSummary(Name,StgId)
select '臨時數據',1

BEGIN

# 自定義變量
declare c_stgId int;
declare c_stgName varchar(50);
declare done INT DEFAULT 0;

declare cr cursor for select Name,StgId from StgSummary ORDER BY StgId desc LIMIT 3;
declare continue handler for not found set done = 1;

-- 打開游標
open cr;
testLoop:LOOP
	-- 獲取結果
	fetch cr into c_stgName,c_stgId;
	IF done = 1 THEN
		LEAVE testLoop; 
	END IF; 
	
  
  SELECT c_stgName,c_stgId;
	
END LOOP testLoop;
-- 關閉游標
close cr;

End;
DROP TEMPORARY TABLE IF EXISTS StgSummary;
End;

最開始的時候,先創建臨時表,再定義游標。但是存儲過程無論如何都保存不了。直接報錯You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DECLARE ...根本原因就是上面提到的注意點(Declare語句只允許出現在BEGIN...END語句中而且必須出現在第一行)。所以最后只能多個加一對BEGIN...END進行隔開。

上述就是小編為大家分享的怎么在Mysql存儲過程中利用游標循環對臨時表進行讀取了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南部县| 黄冈市| 格尔木市| 五莲县| 吉木乃县| 牙克石市| 固原市| 济阳县| 邢台县| 江口县| 浙江省| 曲靖市| 泊头市| 云霄县| 从化市| 琼结县| 民勤县| 赤城县| 芮城县| 彭泽县| 寻乌县| 峡江县| 宜都市| 枣庄市| 齐齐哈尔市| 博野县| 文山县| 皮山县| 博罗县| 临江市| 射洪县| 赤壁市| 屏南县| 扎囊县| 夏河县| 延庆县| 谢通门县| 和平县| 苏州市| 呈贡县| 桦甸市|