mysql_PHP チュートリアルのストアド プロシージャと関数に関するいくつかの問題
最近、MySQL ストアド プロシージャと関数をいくつか作成しましたが、インターネット上に貴重なドキュメントがほとんどなく、そのほとんどがマニュアルからコピーされたものであり、変数をテーブル名として使用するなど、いくつかの実用的な問題が解決できないことがわかりました。
デバッグを繰り返した結果、最終的に解決策を見つけました。比較的断片化された簡単なレコードをいくつか示します。内容の一部は http://my.opera.com/Dereky/blog/show.dml/322997 から転載しています
1. 変数をテーブル名として使用します:
set または destroy ステートメントで変数を定義するだけです。 SQL として直接使用すると、テーブル名は機能しません。mysql は変数名をテーブル名として扱います。他の SQL データベースでも同じことが当てはまります。mssql の解決策は、SQL ステートメント全体を変数として使用し、テーブル名として変数を散在させ、sp_executesql を使用してステートメントを呼び出すことです。
これは mysql5.0 より前では不可能でした。5.0 以降では、sp_executesql と同様の関数を実現できる新しいステートメントが導入されました (プロシージャに対してのみ有効で、関数は動的クエリをサポートしません)。 EXECUTE stmt_name [USING @var_name [, @var_name] ...];
{DROP} PREPARE stmt_name
ここでいくつかの小さな例を示します。 'SELECT SQRT(POW(?,2) + POW(?,2)) AS 斜辺';
mysql> SET @b = 4; b;
+----------------+
|
+----------------+
| ---------- --+
mysql> DEALLOCATE PREPARE stmt1; SET @s = 'SELECT SQRT(POW(?,2) + POW(?,2)) AS 斜辺';
mysql> @s; から stmt2 を準備します;
mysql> SET @b = 8;
+ ---+
+ ------------+
mysql> を準備します。
MySQL バージョンが 5.0.7 以降の場合は、LIMIT 句でも使用できます。例は次のとおりです:
mysql> SET @a=1;mysql> PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?" ;
mysql> @a を使用して STMT を実行 ;
mysql> SET @skip=1;
mysql> を使用して STMT を実行スキップする, @numrows;
PREPARE の使用 注意点:
A: PREPARE stmt_name FROM preparable_stmt; ステートメントを事前定義して stmt_name に割り当てる場合、大文字と小文字は区別されません。
B: preparable_stmt ステートメント内の ? が文字列を表す場合でも、? を引用符で囲む必要はありません。
C: 新しい PREPARE ステートメントが既存の stmt_name を使用する場合、元のステートメントはすぐに解放されます。この新しい PREPARE ステートメントがエラーにより正しく実行できない場合でも。
D: PREPARE stmt_name のスコープは、現在のクライアント接続セッションに表示されます。
E: 事前定義されたステートメントのリソースを解放するには、DEALLOCATE PREPARE 構文を使用できます。
F: EXECUTE stmt_name 構文では、stmt_name が存在しない場合、エラーがトリガーされます。
G: クライアント接続セッションを終了するときにリソースを解放するために DEALLOCATE PREPARE 構文が明示的に呼び出されない場合、サーバーは自動的にリソースを解放します。
H: 事前定義されたステートメントのうち、CREATE TABLE、DELETE、DO、INSERT、REPLACE、SELECT、SET、UPDATE、およびほとんどの SHOW 構文がサポートされています。
I: PREPARE ステートメントはストアド プロシージャやカスタム関数には使用できません。ただし、MySQL 5.0.13 以降では、ストアド プロシージャで使用できるようになりましたが、関数での使用はまだサポートされていません。
これが例です:
CREATE PROCEDURE `p1`(IN id INT UNSIGNED,IN name VARCHAR(11))
BEGIN lable_exit:
BEGIN
SET @SqlCmd = 'SELECT * FROM tA ';
IF id IS NOT NULL THEN
SET @SqlCmd = CONCAT(@SqlCmd, 'WHERE id=?');
SET @a = id;
LEAVE lable_exit;
name が NULL でない場合は、
SET @SqlCmd = CONCAT(@SqlCmd, 'WHERE name LIKE ?');
SET @a = CONCAT(name, '%');
EXECUTE stmt ;
lable_exit;
END lable_exit;
CALL `p1`(NULL,'QQ');理解する PREPARE の使用法を理解すると、変数をテーブル名として使用するのが簡単になります。ただし、実際の操作中に、変数の定義、宣言変数と set @var=value 変数の使用法、パラメーターとして渡される変数など、他のいくつかの問題が発見されました。
テストの結果、set @var=value のように定義された変数を文字列に直接記述すると、宣言された変数とパラメーターで渡された変数を CONCAT を使用して接続する必要があることがわかりました。具体的な原理は研究されていません。
EXECUTE stmt USING @a; このようなステートメントの USING 以降の変数は、宣言によって渡された変数のみを設定でき、パラメーターは使用できません。
さらに、PHP では、mysql ストアド プロシージャを呼び出すときに、PROCEDURE p が指定されたコンテキストで結果セットを返せないなどの問題が常に発生します。
http://www.bkjia.com/PHPjc/317913.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/317913.html
技術記事

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLでテーブルをコピーするには、新しいテーブルの作成、データの挿入、外部キーの設定、インデックスのコピー、トリガー、ストアドプロシージャ、および機能が必要です。特定の手順には、同じ構造を持つ新しいテーブルの作成が含まれます。元のテーブルからデータを新しいテーブルに挿入します。同じ外部キーの制約を設定します(元のテーブルに1つがある場合)。同じインデックスを作成します。同じトリガーを作成します(元のテーブルに1つがある場合)。同じストアドプロシージャまたは関数を作成します(元のテーブルが使用されている場合)。

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。

Passwordが暗号化された形式で保存されているため、MariadbのNavicatはデータベースパスワードを直接表示できません。データベースのセキュリティを確保するには、パスワードをリセットするには3つの方法があります。NAVICATを介してパスワードをリセットし、複雑なパスワードを設定します。構成ファイルを表示します(推奨されていない、高リスク)。システムコマンドラインツールを使用します(推奨されません。コマンドラインツールに習熟する必要があります)。

MySQLのコピーと貼り付けには、次の手順が含まれています。データを選択し、Ctrl C(Windows)またはCMD C(MAC)でコピーします。ターゲットの場所を右クリックして、貼り付けまたはCTRL V(Windows)またはCMD V(MAC)を使用します。コピーされたデータは、ターゲットの場所に挿入されるか、既存のデータを置き換えます(データが既にターゲットの場所に存在するかどうかに応じて)。

NAVICATでSQLを実行する手順:データベースに接続します。 SQLエディターウィンドウを作成します。 SQLクエリまたはスクリプトを書きます。 [実行]ボタンをクリックして、クエリまたはスクリプトを実行します。結果を表示します(クエリが実行された場合)。
