校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL中觸發器和游標的介紹與使用

MySQL中觸發器和游標的介紹與使用

熱門標簽:電話外呼系統改號 武漢網絡外呼系統服務商 怎樣在地圖標注銷售區域 百應電話機器人優勢 啥是企業400電話辦理 曲靖移動外呼系統公司 外呼系統打電話上限是多少 地圖標注費用是多少 南昌三維地圖標注

觸發器簡介

觸發器是和表關聯的特殊的存儲過程,可以在插入,刪除或修改表中的數據時觸發執行,比數據庫本身標準的功能有更精細和更復雜的數據控制能力。

觸發器的優點:

  • 安全性:可以基于數據庫的值使用戶具有操作數據庫的某種權利。例如不允許下班后和節假日修改數據 庫數據;
  • 審計:可以跟蹤用戶對數據庫的操作;
  • 實現復雜的數據完整性規則。例如,觸發器可回退任何企圖吃進超過自己保證金的期貨;
  • 提供了運行計劃任務的另一種方法。例如,如果公司的帳號上的資金低于 5 萬元則立即給財務人員發送 警告數據。

MySQL 中使用觸發器

創建觸發器

創建觸發器的技巧就是記住觸發器的四要素:

  • 監控地點:table;
  • 監控事件:insert/update/delete;
  • 觸發時間:after/before;
  • 觸發事件:insert/update/delete。

創建觸發器的基本語法如下所示:

CREATE TRIGGER
-- trigger_name:觸發器的名稱; 
-- tirgger_time:觸發時機,為 BEFORE 或者 AFTER;
-- trigger_event:觸發事件,為 INSERT、DELETE 或者 UPDATE; 
 trigger_name trigger_time trigger_event 
 ON
 -- tb_name:表示建立觸發器的表名,在哪張表上建立觸發器;
 tb_name
 -- FOR EACH ROW 表示任何一條記錄上的操作滿足觸發事件都會觸發該觸發器。
 FOR EACH ROW
 -- trigger_stmt:觸發器的程序體,可以是一條 SQL 語句或者是用 BEGIN 和 END 包含的多條語句; 
 trigger_stmt
  • trigger_name:觸發器的名稱;
  • tirgger_time:觸發時機,為 BEFORE 或者 AFTER;
  • trigger_event:觸發事件,為 INSERT、DELETE 或者 UPDATE;
  • tb_name:表示建立觸發器的表名,在哪張表上建立觸發器;
  • trigger_stmt:觸發器的程序體,可以是一條 SQL 語句或者是用 BEGIN 和 END 包含的多條語句;
  • FOR EACH ROW 表示任何一條記錄上的操作滿足觸發事件都會觸發該觸發器。

注意:對同一個表相同觸發時間的相同觸發事件,只能定義一個觸發器。

觸發器新舊記錄

MySQL 中定義了 NEW 和 OLD,用來表示觸發器的所在表中,觸發了觸發器的那一行數據:

  • 在 INSERT 型觸發器中,NEW 用來表示將要(BEFORE或已經(AFTER)插入的新數據;
  • 在 UPDATE型觸發器中,OLD 用來表示將要或已經被修改的原數據,NEW 用來表示將要或已經修改為的新 數據;
  • 在 DELETE型觸發器中,OLD 用來表示將要或已經被刪除的原數據。

創建觸發器,當用戶購買商品時,同時更新對應商品庫存記錄,代碼如下所示:

-- 刪除觸發器,drop trigger 觸發器名稱
-- if exists判斷存在才會刪除
drop trigger if exists myty1;
-- 創建觸發器
create trigger mytg1-- myty1觸發器的名稱
after insert on orders-- orders在哪張表上建立觸發器;
for each row
begin
	update product set num = num-new.num where pid=new.pid;
end;
-- 往訂單表插入記錄
insert into orders values(null,2,1);
-- 查詢商品表商品庫存更新情況
select * from product;

創建觸發器,當用戶刪除訂單時,同時更新對應商品庫存記錄,代碼如下所示:

-- 創建觸發器
create trigger mytg2
after delete on orders
for each ROW
begin 
-- 對庫存進行回退,重新加上
	update product set num = num+old.num where pid=old.pid;
end;
-- 刪除訂單記錄
delete from orders where oid = 2;
-- 查詢商品表商品庫存更新情況
select * from product;

before 和 after 的區別

before 在執行語句之前after 在執行語句之后

當訂單商品數量超過庫存時,修改訂單數量為最大庫存:

-- -- 創建 before 觸發器
create trigger mytg3
before insert on orders
for each row 
begin 
	-- 定義一個變量,來接收庫存
	declare n int default 0;
	-- 查詢庫存 把num賦值給n
	select num into n from product where pid = new.pid;
	-- 判斷下單的數量是否大于庫存量
	if new.num>n then
		-- 大于修改下單庫存(庫存改為最大量)
	set new.num = n;
	end if;
	update product set num = num-new.num where pid=new.pid;
end;
-- 往訂單表插入記錄
insert into orders values(null,3,50);
-- 查詢商品表商品庫存更新情況
select * from product;
-- 查詢訂單表
select * from orders;

游標

游標簡介

游標的作用就是用于對查詢數據庫所返回的記錄進行遍歷,以便進行相應的操作。游標有下面這些特征

  • 游標是只讀的,也就是不能更新它;
  • 游標是不能滾動的,也就是只能在一個方向上進行遍歷,不能在記錄之間隨意進退,不能跳過某些記錄;
  • 避免在已經打開游標的表上更新數據。

創建游標

創建游標的語法包含四個部分:

  • 定義游標:declare 游標名 cursor for select 語句;
  • 打開游標:open 游標名;
  • 獲取結果:fetch游標名 into 變量名[,變量名];
  • 關閉游標:close 游標名;

創建一個過程 p1,使用游標返回 test 數據庫中 student 表的第一個學生信息。代碼如下所示:

-- 定義過程
create procedure p1()
begin 
	declare id int;
	declare name varchar(20);
	declare age int;
	-- 定義游標 declare 游標名 cursor for select 語句;
	declare mc cursor for select * from student;
	-- 打開游標 open 游標名;
	open mc;
	-- 獲取數據 fetch 游標名 into 變量名[,變量名];
	fetch mc into id,name,age;
	-- 打印
	select id,name,age;
	-- 關閉游標
	close mc;
end;
-- 調用過程
call p1();

在 test 數據庫創建一個 student2 表,創建一個過程 p2,使用游標提取 student 表中所有學生信息插入到 student2 表中。代碼如下所示:

-- 定義過程
create procedure p3()
begin 
	declare id int;
	declare name varchar(20);
	declare age int;
	declare flag int default 0;
	-- 定義游標 declare 游標名 cursor for select 語句;
	declare mc cursor for select * from student;
	declare continue handler for not found set flag=1;
	-- 打開游標 open 游標名;
	open mc;
	-- 獲取數據 fetch 游標名 into 變量名[,變量名];
	a:loop -- 循環獲取數據
	fetch mc into id,name,age;
	if flag=1 then -- 當無法fetch時觸發continue handler
	leave a;-- 終止循環
	end if;
	-- 進行遍歷,將提取的每一行數據插入到 student2 表中
	insert into student2 values(id,name,age);
	end loop;
	-- 關閉游標
	close mc;
end;
-- 調用過程
call p3();
-- 查詢 student2 表
select * from student2;

總結

到此這篇關于MySQL中觸發器和游標的文章就介紹到這了,更多相關MySQL觸發器和游標內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL系列之五 視圖、存儲函數、存儲過程、觸發器
  • MySQL觸發器的使用
  • mysql觸發器trigger實例詳解
  • MySQL 觸發器的使用和理解
  • 一篇文章帶你深入了解Mysql觸發器

標簽:吉林 資陽 隨州 荊州 滄州 錦州 甘南 黑河

巨人網絡通訊聲明:本文標題《MySQL中觸發器和游標的介紹與使用》,本文關鍵詞  MySQL,中,觸發器,和,游,標的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中觸發器和游標的介紹與使用》相關的同類信息!
  • 本頁收集關于MySQL中觸發器和游標的介紹與使用的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲人成小说网站色在线 | 精品久久久久香蕉网| proumb性欧美在线观看| 风间由美一区二区三区在线观看| 久久超碰97人人做人人爱| 久久激五月天综合精品| 国产美女在线观看一区| 国产精品资源在线看| 国产91丝袜在线播放0| 成人深夜福利app| 91蜜桃传媒精品久久久一区二区| 91女人视频在线观看| 欧美在线视频日韩| 日韩免费高清av| 久久精品欧美一区二区三区不卡| 国产精品免费久久| 亚洲在线一区二区三区| 丝袜亚洲精品中文字幕一区| 久久99精品国产| 福利电影一区二区| 欧美在线不卡一区| 日韩欧美国产麻豆| 国产精品欧美一区二区三区| 一区二区三区国产精品| 美国精品在线观看| www.欧美色图| 91精品国产综合久久久久| 久久久久国产成人精品亚洲午夜| 亚洲色图20p| 久久精品国产亚洲aⅴ | 欧美亚洲图片小说| 欧美不卡一区二区三区四区| 国产精品久久久久影院色老大| 一区二区三区四区五区视频在线观看| 亚洲高清不卡在线观看| 国内久久婷婷综合| 欧美亚洲免费在线一区| 久久蜜桃av一区精品变态类天堂| 一区二区三区在线播| 国产一区二区三区在线观看免费| 91蝌蚪porny九色| 欧美电视剧免费全集观看| 亚洲特黄一级片| 国产成人综合视频| 欧美日韩高清一区二区三区| 中文字幕va一区二区三区| 日本强好片久久久久久aaa| 成人avav影音| 欧美精品一区二区精品网| 亚洲精品乱码久久久久久黑人 | 国产欧美一区视频| 亚洲18影院在线观看| 不卡av免费在线观看| 亚洲精品一区二区三区在线观看| 亚洲.国产.中文慕字在线| 91亚洲永久精品| 中文字幕不卡三区| 国产成人综合在线观看| 日韩精品在线看片z| 奇米影视一区二区三区小说| 欧美在线一二三| 久久婷婷久久一区二区三区| 婷婷久久综合九色综合绿巨人| 色噜噜偷拍精品综合在线| 国产精品久久久久久久久晋中 | 韩国女主播一区二区三区| 欧美欧美欧美欧美首页| 亚洲成人你懂的| 欧亚洲嫩模精品一区三区| 一区二区三区高清| 在线中文字幕不卡| 亚洲一区二区精品视频| 欧美日精品一区视频| 亚洲第一电影网| 欧美日韩精品电影| 亚洲成av人综合在线观看| 欧美日韩精品免费观看视频| 亚洲bdsm女犯bdsm网站| 制服丝袜中文字幕一区| 日本亚洲天堂网| 精品91自产拍在线观看一区| 国产一区免费电影| 亚洲国产精品ⅴa在线观看| 99久久精品免费看国产| 亚洲免费色视频| 欧美日韩中文精品| 日韩激情一二三区| 精品国产髙清在线看国产毛片| 久热成人在线视频| 国产精品午夜在线| 91在线云播放| 国产精品久久久久久久岛一牛影视 | 亚洲欧美另类小说| 色诱亚洲精品久久久久久| 亚洲乱码中文字幕| 欧美日韩黄色影视| 韩国女主播一区| 亚洲欧洲日韩综合一区二区| 欧美日韩高清不卡| 国产福利一区二区三区视频在线 | 久久97超碰色| 最新国产成人在线观看| 欧美日韩一二三| 国产又粗又猛又爽又黄91精品| 亚洲欧洲一区二区在线播放| 91精品视频网| 成人综合婷婷国产精品久久蜜臀 | 91免费视频网址| 日韩在线一二三区| 久久久久国产成人精品亚洲午夜| 99免费精品视频| 免费在线成人网| 亚洲色欲色欲www| 日韩亚洲欧美在线| 色婷婷亚洲综合| 国产毛片一区二区| 亚洲高清视频在线| 国产精品国产精品国产专区不蜜 | 午夜国产精品影院在线观看| 久久久久久久久伊人| 欧美精品欧美精品系列| 9l国产精品久久久久麻豆| 蜜臀久久99精品久久久久宅男| 国产精品久线观看视频| 日韩欧美一区二区三区在线| 色中色一区二区| 成人听书哪个软件好| 日韩av一级电影| 亚洲综合小说图片| 成人欧美一区二区三区白人| 欧美电视剧免费全集观看| 欧美日高清视频| 91麻豆精东视频| 成人免费毛片aaaaa**| 国内精品国产成人国产三级粉色| 天堂成人国产精品一区| 亚洲午夜羞羞片| 亚洲免费在线观看| 国产精品无圣光一区二区| 日韩小视频在线观看专区| 欧美三级三级三级爽爽爽| 99精品久久99久久久久| 成人av电影在线观看| 成人晚上爱看视频| 丰满少妇在线播放bd日韩电影| 国产自产v一区二区三区c| 美腿丝袜亚洲综合| 乱中年女人伦av一区二区| 美女一区二区三区| 久草这里只有精品视频| 久草在线在线精品观看| 国产一区二区三区黄视频 | 日本福利一区二区| 99re成人在线| 91精品办公室少妇高潮对白| 91视频精品在这里| 一本大道久久精品懂色aⅴ| 色噜噜久久综合| 欧美放荡的少妇| 日韩精品中文字幕在线不卡尤物| 欧美大度的电影原声| 欧美电视剧免费全集观看| 久久久久久久久久美女| 国产精品网曝门| 夜夜精品视频一区二区 | 一区二区三区在线视频播放| 亚洲综合无码一区二区| 视频在线观看91| 国产精品自拍av| 91网站视频在线观看| 色噜噜夜夜夜综合网| 欧美色倩网站大全免费| 日韩欧美激情四射| 国产精品三级视频| 亚洲成va人在线观看| 韩国v欧美v亚洲v日本v| 99久久99久久久精品齐齐 | 国产综合色精品一区二区三区| 国产**成人网毛片九色| 99国产精品视频免费观看| 日本久久一区二区三区| 欧美大胆人体bbbb| 亚洲欧洲日韩av| 美女一区二区三区在线观看| 成人av资源站| 日韩一区二区在线观看视频 | 91福利资源站| 日韩三级高清在线| 亚洲日穴在线视频| 日本 国产 欧美色综合| 成人短视频下载| 欧美乱妇20p| 亚洲人成7777| 精品一区二区三区视频在线观看| 99久久精品国产一区二区三区| 日韩你懂的在线播放| 亚洲免费视频成人| 丁香激情综合五月| 精品国产伦理网| 丝袜国产日韩另类美女|