MySQL でストアド プロシージャを作成し、データ テーブルに新しいフィールドを追加する方法の分析

MySQL でストアド プロシージャを作成し、データ テーブルに新しいフィールドを追加する方法の分析

この記事では、例を使用して、MySQL でストアド プロシージャを作成し、データ テーブルに新しいフィールドを追加する方法について説明します。ご参考までに、詳細は以下の通りです。

必要:

データベースのテーブルに新しいフィールドを追加します (フィールドが既に存在する場合は何も実行されません。フィールドが存在しない場合は新しいフィールドが追加されます)

長い間Baiduを検索しましたが、要件を満たす例はありませんでした。参照して自分で理解するしかありませんでした。ついに、私はそれを理解しました。以下はいくつかのバージョンの変更点です。

初版:

区切り文字 $$
CREATE PROCEDURE insert_column()
始める
存在しない場合(information_schema.columnsから1を選択)
table_schema='ltivalley' かつ table_name='t_luck' の場合
かつ、column_name='sss' ) の場合
テーブル ltivalley.t_luck を変更し、 sss varchar(255) を Null 以外に追加します。
終了の場合;
終わり
$$
区切り文字 ;

このストアド プロシージャは、ltivalley データベースの t_luck テーブルに新しい sss フィールドを追加できますが、デッドコードされており柔軟性がないため、役に立ちません。

第2版​​:

区切り文字 $$
CREATE PROCEDURE insert_column(in dbname varchar(255),in tbname varchar(255),in colname varchar(255))
@sql_1 を concat("存在しない場合は(SELECT 1 FROM
information_schema.columns WHERE table_schema=",dbname,"
AND テーブル名=",tbname," AND 列名=",colname,")
それから
テーブル ",dbname,".",tbname," を変更し、",colname," を追加します。
varchar(255) は null ではありません。
終了if;");
@sql_1 からステートメントを準備します。
ステートメントの実行;
DEALLOCATE PREPARE ステートメント;
終わり
$$
区切り文字 ;

ストアド プロシージャの作成には問題はありませんが、呼び出し時にエラーが発生し、「IF」の前後でエラーが報告されます。これは、MySQL では、IF はストアド プロシージャ内にしか存在できないためです。ここで EXECUTE stmt を使用して実行すると、ストアド プロシージャ内の if ステートメントを実行しないのと同じになるため、エラーが報告され、実行できません。だから無駄だよ!

第3版

区切り文字 $$
CREATE PROCEDURE insert_column(in dbname varchar(255),in tbname varchar(255),in colname varchar(255))
始める
SET @selec=CONCAT('SELECT 1 FROM information_schema.columns WHERE table_schema="',dbname,'" AND table_name="',tbname,'" AND column_name="',colname,'"');
@selec から selec を準備します。
SET @addcol=CONCAT('ALTER TABLE ',dbname,'.',tbname,' ADD ',colname,' VARCHAR(255)');
addcol を @addcol から準備します。
存在しない場合(選択を実行)
addcol を実行します。
終了の場合;
終わり
$$
区切り文字 ;

不明な理由により、EXECUTE 選択ステートメントを IF NOT EXISTS() で実行できないため、ストアド プロシージャを作成できません。だから無駄だよ!

アルティメットエディション

insert_column が存在する場合はプロシージャを削除します。
区切り文字 $$
CREATE PROCEDURE insert_column(in dbname varchar(255),in tbname varchar(255),in colname varchar(255))
始める
@iscolexists = 0 に設定します。
SET @selec=CONCAT('SELECT count(*) into @iscolexists FROM information_schema.columns WHERE table_schema="',dbname,'" AND table_name="',tbname,'" AND column_name="',colname,'"');
@selec から selec を準備します。
選択を実行してください。
DEALLOCATE PREPARE を選択します。
SET @addcol=CONCAT('ALTER TABLE ',dbname,'.',tbname,' ADD ',colname,' VARCHAR(255)');
addcol を @addcol から準備します。
IF(@iscolexists=0)の場合
addcol を実行します。
終了の場合;
終わり
$$
区切り文字 ;

最終結果については、まずEXECUTE selecを実行し、その結果を変数@iscolexistsに格納します。次に、 IF()@iscolexistsの値を判断し、対応する操作を実行します。利用可能!

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL ストアド プロシージャ スキル」、「MySQL 共通関数の概要」、「MySQL ログ操作スキル」、「MySQL トランザクション操作スキルの概要」、および「MySQL データベース ロック関連スキルの概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQLでデータテーブルを作成するときにエンジンMyISAM/InnoDBを設定する
  • MySQL でデータ テーブルを作成し、主キーと外部キーの関係を確立する方法の詳細な説明
  • MySQL のデータベースとデータ テーブルのエンコード形式を表示、作成、変更します。
  • MySQLでテーブルを作成および削除するための詳細な手順と構文
  • Mysqlでデータテーブルインスタンスコードを作成する
  • MySQL で 800 万エントリのテスト データ テーブルをすばやく作成する方法

<<:  SSH経由でリモートLinuxシステムでコマンドを実行する方法

>>:  Node.js でのクラスター作成に関する簡単な説明

推薦する

Dockerコンテナでユーザーを分離する方法

前回の記事「Docker コンテナの UID と GID を理解する」では、Docker コンテナ内...

JavaScript 手ぶれ補正のケーススタディ

原理手ぶれ補正の原理は、イベントをトリガーすることはできますが、イベントがトリガーされてから n 秒...

Dockerはコンテナポートバインディングのローカルポートを実装します

今日、イメージを起動した後、HTTP リクエスト経由でアクセスできないという小さな問題が発生しました...

vmware14Pro で Ubuntu システム インターフェイスが小さすぎる問題の解決方法の詳細な説明

1. 動作環境vmware14proウブントゥ 16.04LTS 2. 問題の説明vmware14P...

要素の円弧モーションを実現する CSS3 サンプルコード

CSS を使用して要素の円弧の動きを制御する方法CSS3 の新しい属性 transfrom トランジ...

MySQL 起動失敗の問題とシナリオ分析

1. ワンストップソリューション1. 問題の分析と特定 # MySQL設定ファイルを見つけて、MyS...

Navicat PremiumはMySQLデータベースを操作します(SQL文を実行します)

1. Navicatの紹介1. Navicat とは何ですか? Navicat は強力な MySQ...

Ajax responseText による JSON データの解析のケース スタディ

ajax 処理後にサーバーから返される responseText が JSON データであるという問...

組み込みオブジェクトに関するJavascriptの基礎

目次1. 組み込みオブジェクトの紹介1.1 数学オブジェクト1.2 数学における方法1.3 日付オブ...

MySQLに絵文字表現を保存する詳細な手順

原因: java.sql.SQLException: 列の文字列値が正しくありません: '\...

よく忘れられがちな CSS のヒント 26 選

これは、よく使われるけれども忘れられがちな CSS 実装方法のコレクションです。抜けや追加があれば、...

WeChatミニプログラムでのマップの正しい使用例

目次序文1. 準備2. 実際の戦闘2.1 ミニプログラムの権限を設定する2.2 カプセル化ツールの機...

Vue + 要素を使用して背景データをオプションに動的に表示する

必要:ハードコードされたデータの代わりに、セレクター内のオプション値の動的な表示を実装します。私のロ...

Linux SecureCRT の文字化けの解決方法

SecureCRT が文字化けした文字を表示する状況を見てみましょう。例えば: ではリセットしてみま...

携帯電話番号の歩数記録を取得するWeChatアプレット

序文最近、小さなプログラムを開発しているときに、このような問題に遭遇しました。ユーザーが認証をクリッ...