1. テーブルを作成する<br /> まず、2 つのテーブル (users テーブルと number テーブル) を作成します。具体的な設計は次のとおりです。 2. ストアド プロシージャ<br /> ユーザー テーブルにデータを挿入するストアド プロシージャを作成します。作成プロセスは次のとおりです。 コードは次のとおりです 始める #ルーチン本体はここに記述します... n bigint を宣言します。 n = 201121029684 に設定します。 n <= 201121029694 の場合 する ユーザ(student_ID)の値(n)に挿入します。 n = n + 1 と設定します。 終了しながら; 終わり
ストアド プロシージャ全体が記述されました。もちろん、これは非常に単純な例であり、参考用です。 3. トリガー トリガーを書き込む前に、まずユーザーデータをクリアします テーブルユーザーを切り捨てます。 これで 2 つのテーブルができました。必要なのは、ユーザーにデータを挿入すると、それに応じて番号も変更されるようにすることです。 たとえば、数値テーブルには id=1、num=0 という初期データがあります。 ユーザーにデータを挿入すると、数値テーブルの num フィールドが 1 増加し、ユーザー数が記録されます。 この小さな機能を実装してみましょう。 ユーザーテーブルを右クリックし、「テーブルのデザイン」を選択します。
始める 更新番号 num = (users から count(*) を選択) を設定します。 終わり 保存した後、users テーブルに新しいデータを追加し、number のデータを確認します。number テーブルのデータも魔法のように変更されていることがわかります。ぜひ試してみてください。 追記: ストアド プロシージャはプログラマー自身が実行する必要がありますが、トリガーは、その名前が示すように自動的にトリガーされます。 4. カーソルの使用<br /> ここで実行したいのは、student_ID フィールドに 100 を追加することです。この例を使用して、カーソルの使用方法を簡単に説明します。 ストアドプロシージャを作成します。作成方法については上記の手順を参照してください。ストアド プロシージャ コードは次のとおりです。 始める #ルーチン本体はここに記述します... tmp bigint のデフォルトを 0 と宣言します。 宣言 cur CURSOR FOR SELECT student_ID FROM users; -- カーソルを定義します/* 02000 次のいずれかの例外が発生しました: SELECT INTO ステートメントまたは INSERT ステートメントのサブクエリの結果は空のテーブルになります。 検索された UPDATE または DELETE ステートメント内で識別された行数は 0 です。 FETCH ステートメントで参照されるカーソル位置は、結果テーブルの最後の行の後にあります。 */ SQLSTATE '02000' の CONTINUE HANDLER を宣言し、tmp を 0 に設定します。 OPEN cur; -- カーソルを開きます FETCH cur INTO tmp; -- カーソルを 1 ステップ下に移動します WHILE (tmp != 0) する select tmp; -- tmp を印刷すると、tmp がポインタのようなものだということが分かります。これは、先頭の最初の行を指します。カーソルが 1 ステップ移動すると、次のレコード行を指します。UPDATE users 学生IDをtmp + 100に設定します ここで、student_ID = tmp; cur を tmp にフェッチします。 終了しながら; CLOSE cur; -- カーソルを閉じる END 上記のストアド プロシージャを実行すると、ユーザーのデータが希望どおりに変更されていることがわかります。 以下もご興味があるかもしれません:
|
<<: JavaScript における clientWidth、offsetWidth、scrollWidth の違い
1. vue-cli がプロジェクト パッケージを作成した後にページが空白になる問題の解決方法コマン...
上はシステム時間、下はハードウェア時間です。ここでは変更を加えているので、同じくらいの速さになってい...
目次前提条件DNSドメイン名解決プロセス外部ネットワークマッピングnginxコア知識nginxとはア...
目次ブートストラップと関連コンテンツの紹介グリッドシステムネストされた列列オフセット列の並べ替えナビ...
.NET SDK ダウンロード リンクhttps://dotnet.microsoft.com/do...
目次1. 開発モードとリリースモードに異なるパッケージエントリポイントを指定する2. 外部CDNリソ...
MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例最近のプロ...
目次1. 概要1.1 querySelector() と querySelectorAll() の使...
Nginx の公式 Web サイトから Windows バージョンの Nginx をダウンロードしま...
MySQL データベースにデータを挿入します。以前はよく使われていた INSERT INTO テーブ...
1. 監視計画監視項目を作成する前に、何を監視するのか、どのように監視するのか、監視データをどのよう...
今日は新しいCSS特殊効果、波型ウォーターボール効果を学びました。これもとても美しいです HTML:...
この記事では、例を使用して MySQL の共有ロックと排他ロックの使用方法を説明します。ご参考までに...
目次0. モジュールとは何か1.モジュールの読み込み1.1 方法1 1.2 方法2 2. 輸出と輸入...
HTML4 についてHTML (XHTML ではありません)、MIME タイプは text/html...