MySQL で準備、実行、割り当て解除ステートメントを使用するチュートリアル

MySQL で準備、実行、割り当て解除ステートメントを使用するチュートリアル

序文

MySQLでは、準備、実行、割り当て解除を正式にはPREPARE STATEMENTと呼びます。私は[準備されたステートメント]と呼ぶことに慣れています。使い方は非常に簡単です。では、早速詳しい紹介を見ていきましょう。

サンプルコード

準備可能な stmt から stmt_name を準備します

stmt_name を実行
 [@var_name [, @var_name] を使用...] -

{DEALLOCATE | DROP} stmt_name を準備する

例えば:

mysql> PREPARE pr1 FROM 'SELECT ?+?';
クエリは正常、影響を受けた行は 0 行 (0.01 秒)
声明文を準備

mysql> @a=1、@b=10 を設定します。
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

mysql> @a、@b を使用して pr1 を実行します。
+------+
| ?+? |
+------+
| 11 |
+------+
セット内の 1 行 (0.00 秒)

mysql> EXECUTE pr1 USING 1, 2; -- ユーザー変数のみを渡すことができます。
エラー1064(42000):SQL構文にエラーがあります。MySQLサーバーのバージョンに対応するマニュアルを確認してください。 
1行目の「1, 2」付近で使用する正しい構文

mysql> PREPARE pr1 の割り当てを解除します。
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

PAREPARE STATEMENT を使用すると、各 SQL 実行の構文解析を減らすことができます。たとえば、WHERE 条件付きの SELECT および DELETE、または UPDATE、INSERT を実行する場合、その都度変数値を変更するだけで済みます。

SQL インジェクションも防止でき、パラメータ値にエスケープ文字や区切り文字を含めることができます。

アプリケーションまたは SQL スクリプトに適用可能です。

その他の使用法:

同様に、PREPARE ... FROM はユーザー変数に直接接続できます。

mysql> テーブル a (a int);
クエリは正常、影響を受けた行は 0 行 (0.26 秒)

mysql> INSERT INTO a SELECT 1;
クエリは正常、1 行が影響を受けました (0.04 秒)
記録: 1 重複: 0 警告: 0

mysql> INSERT INTO a SELECT 2;
クエリは正常、1 行が影響を受けました (0.04 秒)
記録: 1 重複: 0 警告: 0

mysql> INSERT INTO a SELECT 3;
クエリは正常、1 行が影響を受けました (0.04 秒)
記録: 1 重複: 0 警告: 0

mysql> SET @select_test = CONCAT('SELECT * FROM ', @table_name);
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

mysql> SET @テーブル名 = 'a';
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

mysql> @select_test から pr2 を準備します。
クエリは正常、影響を受けた行は 0 行 (0.00 秒)
声明文を準備

mysql> pr2 を実行します。
+------+
| ア |
+------+
| 1 |
| 2 |
| 3 |
+------+
セット内の 3 行 (0.00 秒)

mysql> DROP PREPARE pr2; -- ここで DROP を DEALLOCATE に置き換えることができます
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

EXECUTE ステートメントを完了するたびに、DEALLOCATE PREPARE ... ステートメントを実行して、実行に使用されたすべてのデータベース リソース (カーソルなど) を解放する習慣を身に付けてください。

さらに、セッション内に準備されたステートメントが多すぎる場合、max_prepared_stmt_count の上限に達する可能性があります。

準備されたステートメントは作成者のセッションでのみ使用でき、他のセッションでは使用できません。

さらに、何らかの方法 (正常または異常) でセッションを終了すると、以前に定義した準備済みステートメントは存在しなくなります。

ストアド プロシージャで使用する場合、プロシージャ内で DEALLOCATE が実行されないと、準備されたステートメントはストアド プロシージャの終了後も有効になります。

要約する

上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただき、ありがとうございます。

以下もご興味があるかもしれません:
  • Mysqlのprepare前処理の具体的な使用法
  • MySQL の使用法とバグ分析のプロセスを準備する

<<:  nginx proxy_cache バッチキャッシュクリアスクリプトの紹介

>>:  JS を使用して要素がビューポート内にあるかどうかを確認する方法

推薦する

HTMLでのラジオ値の取得、割り当て、登録の詳細な説明

1. ラジオのグループ化名前が同じであれば、それらはグループであり、つまり、次のようにグループ内で選...

フロントエンドの状態管理(パート 1)

目次1. フロントエンドの状態管理とは何ですか? 2. ヴュークス3. バス4. ウェブストレージ序...

Linux でシェル スクリプトを使用して jar パッケージ プロジェクトを展開するための完全な手順

1. JDKをインストールする コンピュータの動作桁を確認します。 uname -ar 2017 x...

CSSスタイルの記述順序と命名規則と注意事項

書き順の重要性ブラウザのリフローを減らし、ブラウザのDOMレンダリングパフォーマンスを向上させる①:...

Nginx 7層負荷分散のいくつかのスケジューリングアルゴリズムの簡単な理解

この記事は主に、Nginx 7 層負荷分散のいくつかのスケジューリング アルゴリズムを紹介します。こ...

MySQL 上級学習ノート (パート 3): MySQL 論理アーキテクチャの紹介、MySQL ストレージ エンジンの詳細な説明

MySQL 論理アーキテクチャの概要他のデータベースと比較すると、MySQL は、そのアーキテクチャ...

HTTP および HTTP コラボレーション Web サーバー アクセス フロー図

Web サーバーは、独立したドメイン名を持つ複数の Web サイトを構築できるほか、通信経路上のトラ...

Tomcat の maxPostSize 設定に関する問題と注意事項

1. maxPostSize を設定する理由は何ですか? tomcat コンテナには送信データのサイ...

nginx を使用して正規表現で指定された URL リクエストを傍受する方法

nginx サーバーnginx は、静的ファイルの処理に非常に効率的な優れた Web サーバーです。...

JS配列メソッドsome、every、findの使用に関する詳細

目次1. いくつか2. すべての3. 見つける1. いくつかsome()メソッドは、指定された関数の...

MySQLスケーラブル設計の基本原則

目次序文1. スケーラビリティとは何ですか?スケールアウトの利点:スケールアウトのデメリット:スケー...

VMware マルチノード環境を構成する方法

このチュートリアルでは CentOS 7 64 ビットを使用します。各仮想マシンに 2GB のメモリ...

Windows でのシンプルな Mysql バックアップ BAT スクリプトの共有

序文この記事では、Windows で Mysql をバックアップするための簡単な BAT スクリプト...

シンプルなページカウントダウンを実現するJavaScript

この記事では、参考までに、シンプルなページカウントダウンを実装するためのJavaScriptの具体的...

ウェブサイトのフロントエンドをエレガントでユーザーにとって魅力的なものにする方法

ウェブフロントエンドのウェブサイトの気質は感情であり、言葉なしでユーザーを魅了できる感情です。では、...