MySQLトリガーについて深く理解するための記事

MySQLトリガーについて深く理解するための記事

学校データベースの学生、コース、sc テーブルに基づいて、次の要件を満たすトリガーを作成します。

數據庫navicat cmd界面運行

1. SC テーブルを挿入または変更するときに、テスト スコアが 0 ~ 100 の範囲外の場合、挿入または変更操作はキャンセルされます。

区切り文字 ;
`tri_update_grade` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の「sc」の更新前に「tri_update_grade」トリガーを作成します。
new.grade > 100の場合
sc から削除します。
そうでない場合は、new.grade < 0 の場合
sc から削除します。
終了の場合;
終わり
;;
区切り文字 ;
`tri_insert_grade` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の `sc` に INSERT する前に `tri_insert_grade` トリガーを作成します
new.grade > 100の場合
sc から削除します。
そうでない場合は、new.grade < 0 の場合
sc から削除します。
終了の場合;
終わり
;;

2. SC テーブルに挿入する際、学生のコース選択の合計単位数が 30 を超えると、エラーが報告され、挿入はキャンセルされます。

区切り文字 ;
`tri_insert_credit` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の「sc」に挿入する前に「tri_insert_credit」トリガーを作成します。
Student から sum(Ccredit) INTO @sumcred を選択し、SC.Sno=Student.Sno で SC を結合し、Course.Cno=SC.Cno で Course を結合します (WHERE sc.Sno=new.Sno);
(@sumcred>30) の場合
それから
sc から削除します。
終了の場合;
終わり
;;

3. SC表を修正する場合、試験に不合格となった学生のコース選択記録を修正することはできません。

区切り文字 ;
`tri_grade` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の `sc` の更新前に `tri_grade` トリガーを作成します
sc から grade INTO @gra を選択します (sno=new.sno かつ sno=new.sno)。
(@gra >= 60) の場合
それから
new.grade=20 を設定します。
それ以外
sc から削除します。
終了の場合;
終わり
;;

4. STUDENT テーブルに挿入するときに、年齢が空の場合、学生の年齢はすべての学生の平均年齢に設定されます。

区切り文字 ;
`tri_student` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の「student」に挿入する前に「tri_student」トリガーを作成します。
学生からavg(Sage) INTO @avgageを選択します。
SET @old_age = new.Sage;
@old_age が NULL の場合
それから
new.Sage=@avgage; を設定します。
終了の場合;
終わり
;;

5. STUDENT テーブルに 2 つの列を追加して、生徒の平均スコアと成績を保存し、SC テーブルに挿入した後、生徒の平均スコアと成績を自動的に維持します (85 ~ 100 の場合、成績は「優秀」、60 ~ 85 の場合、成績は「良好」、60 未満の場合、成績は「不良」)

区切り文字 ;
`tri_comment` が存在する場合はトリガーを削除します。
区切り文字 ;;
各行の「student」の更新前にトリガー「tri_comment」を作成します。
sc から avg(Grade) INTO @avggra を選択します (sno=new.sno);
@avggra > 85の場合
sc を更新し、new.Savg=@avggra、new.Scomment="you" を設定します。
そうでない場合、@avggra > 60 かつ @avggra <= 85 の場合
sc を更新し、new.Savg=@avggra、new.Scomment="you" を設定します。
それ以外
sc を更新し、new.Savg=@avggra、new.Scomment='cha' を設定します。
終了の場合;
終了の場合;
終わり
;;
区切り文字 ;

要約する

この記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL イベントとトリガーのトピックの絞り込み
  • 初心者から熟練者まで使えるMySQLデータベーストリガー
  • MySQL ストアド プロシージャ、トリガー、イベント スケジューラの入門ガイド
  • MySQLトリガートリガー例の詳細な説明
  • MySQL トリガーの使用方法と利点と欠点の紹介
  • バックアップと削除のためにリアルタイムでステートメントを検出するMySQLトリガーの考え方の詳細な説明
  • MySQLトリガーの使用
  • MySQLトリガーの使用
  • MySQLトリガーの使い方を簡単に説明すると

<<:  HTML内の画像はbase64でエンコードされた文字列に直接置き換えられます

>>:  DockerでPython環境をパッケージ化するプロセスの詳細な説明

推薦する

HTML ウェブページハイパーリンクタグ

HTML ウェブ ページのハイパーリンク タグの学習チュートリアル リンク タグの属性 リンクは、ウ...

固定、流動的、柔軟なウェブページレイアウトの長所と短所の分析

ウェブデザイナーを長い間悩ませてきた疑問があります。それは、固定レイアウト、流動的レイアウト、柔軟レ...

MySQL シリーズ 7 MySQL ストレージ エンジン

1. MyISAM ストレージエンジン欠点:トランザクションはサポートされていません最小粒度ロック:...

HTML の値属性と名前属性の機能と使用法の紹介

1. ボタンで使用される値は、「OK」、「削除」など、ボタンに表示されるテキストを指します。 2. ...

HTMLインライン要素とブロックレベル要素の基本概念と使用例

HTML タグには、インライン要素とブロックレベル要素の 2 種類があります。まず、インライン要素と...

Macにmysql5.7.18をインストールする詳細な手順

1. ツール今必要なツールは2つあります: MySQLサーバー (mysql-5.7.18)、MyS...

MySQL 8.0.15 のインストールと設定方法のグラフィックチュートリアル (Win10 Home バージョン 64)

超初心者の私は、MySQL を学び始めたばかりで、インストール プロセス中に多くの問題に遭遇しました...

vue-cli 設定では Vuex の完全なプロセスレコードを使用します

目次序文インストールと使用方法モジュラー管理Vuex の状態永続性要約する序文Vue 開発では、ユー...

Vue が天気予報機能を実装

この記事では、天気予報機能を実現するためのVueの具体的なコードを参考までに共有します。具体的な内容...

MySQL 5.7.17 圧縮パッケージのインストール不要の構成プロセス図

MySQL データベース管理ソフトウェアには、エンタープライズ エディションとコミュニティ エディシ...

OEL7.6 ソースコードから MYSQL5.7 をインストールするチュートリアル

まず、公式サイト https://dev.mysql.com/downloads/mysql/5.7...

XHTML 入門チュートリアル: フォーム タグ

<br />フォームはユーザーが情報を送信するための重要なチャネルです。このセクションで...

Windows で virtualenv を使用して仮想環境を作成する方法 (2 つの方法)

オペレーティング システム: windows10_x64 Python バージョン: 3.6.8仮想...

Tomcat が https アクセスをサポートするための手順の説明

tomcat を https アクセスに対応させる方法ステップ: (1)キーストアファイルを生成する...

VM VirtualBox 仮想マシンのマウント共有フォルダ

一つの環境CentOS 7にVMware Toolsをインストールしてホストの共有フォルダへのアクセ...