婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 一篇文章帶你深入了解Mysql觸發器

一篇文章帶你深入了解Mysql觸發器

熱門標簽:拉卡拉外呼系統 外東北地圖標注 400電話可以辦理嗎 大眾點評星級酒店地圖標注 話務外呼系統怎么樣 云南電商智能外呼系統價格 智能外呼系統復位 高清地圖標注道路 臨清電話機器人

基于school數據庫中的student, course, sc表,創建滿足下述要求的觸發器:

數據庫navicat cmd界面運行

1.對SC表進行插入或修改時,如果考試成績不在0-100范圍內時,則撤銷插入或修改操作。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_update_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_update_grade` BEFORE UPDATE ON `sc` FOR EACH ROW begin
if new.grade > 100 then
delete from sc;
elseif new.grade  0 then
delete from sc;
end if;
end
;;
DELIMITER ;
DROP TRIGGER IF EXISTS `tri_insert_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_insert_grade` BEFORE INSERT ON `sc` FOR EACH ROW begin
if new.grade > 100 then
delete from sc;
elseif new.grade  0 then
delete from sc;
end if;
end
;;

2.對SC表進行插入時,如果學生的選課總學分超過30,則報錯并撤銷插入。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_insert_credit`;
DELIMITER ;;
CREATE TRIGGER `tri_insert_credit` BEFORE INSERT ON `sc` FOR EACH ROW begin
SELECT sum(Ccredit) INTO @sumcred from Student join SC on SC.Sno=Student.Sno join Course on Course.Cno=SC.Cno WHERE sc.Sno=new.Sno;
if (@sumcred>30)
then
delete from sc;
end if;
end
;;

3.對SC表進行修改時,不允許修改考試成績不及格的學生選課記錄。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_grade` BEFORE UPDATE ON `sc` FOR EACH ROW begin
select grade INTO @gra from sc where sno=new.sno and sno=new.sno;
if (@gra >= 60)
then
set new.grade=20;
else
delete from sc;
end if;
end
;;

4.對STUDENT表進行插入時,如果年齡為空,則將該生年齡設置為所有學生年齡的平均值。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_student`;
DELIMITER ;;
CREATE TRIGGER `tri_student` BEFORE INSERT ON `student` FOR EACH ROW begin
select avg(Sage) INTO @avgage from student;
SET @old_age = new.Sage;
if @old_age IS NULL
then
set new.Sage=@avgage;
end if;
end
;;

5.在STUDENT表中增加兩列,分別用來存放學生的平均成績和等級,并對SC表進行插入后,自動維護學生的平均成績和等級(85-100,等級為“優"; 60-85,等級為“良”,60 以下,等級為“差")

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_comment`;
DELIMITER ;;
CREATE TRIGGER `tri_comment` BEFORE UPDATE ON `student` FOR EACH ROW begin
select avg(Grade) INTO @avggra from sc where sno=new.sno;
if @avggra > 85 then
update sc set new.Savg=@avggra,new.Scomment="you";
else if @avggra > 60 and @avggra = 85 then
update sc set new.Savg=@avggra,new.Scomment="you";
else
update sc set new.Savg=@avggra,new.Scomment='cha';
end if;
end if;
end
;;
DELIMITER ;

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

您可能感興趣的文章:
  • Mysql觸發器在PHP項目中用來做信息備份、恢復和清空
  • MySQL觸發器的使用
  • 詳解MySQL數據庫之觸發器
  • mysql 觸發器語法與應用示例
  • MySql視圖觸發器存儲過程詳解
  • mysql觸發器實時檢測一條語句進行備份刪除思路詳解

標簽:阿里 山西 無錫 溫州 定西 三明 揚州 福州

巨人網絡通訊聲明:本文標題《一篇文章帶你深入了解Mysql觸發器》,本文關鍵詞  一篇,文章,帶你,深入,了解,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《一篇文章帶你深入了解Mysql觸發器》相關的同類信息!
  • 本頁收集關于一篇文章帶你深入了解Mysql觸發器的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 大余县| 武陟县| 合川市| 琼结县| 霍林郭勒市| 西安市| 巩留县| 洪泽县| 蒲城县| 临城县| 泰来县| 北碚区| 台江县| 花莲县| 康平县| 邳州市| 客服| 长乐市| 隆尧县| 晋江市| 色达县| 抚顺市| 昭平县| 弥渡县| 郸城县| 日喀则市| 泾川县| 垣曲县| 青铜峡市| 吉安县| 讷河市| 纳雍县| 鹰潭市| 社会| 镇赉县| 瑞丽市| 万宁市| 吴桥县| 南靖县| 金湖县| 兴义市|