SQL 関数内で動的に名前が付けられたテーブルにアクセスするにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-11-07 04:20:03
オリジナル
1004 人が閲覧しました

How Can I Access Dynamically Named Tables Within a SQL Function?

ストアド プロシージャ関数の動的テーブル名

SQL では、関数は不変であり、データを変更できません。したがって、プリペアド ステートメントを関数内で使用することはできず、動的な名前を持つテーブルにアクセスしようとするときに問題が生じます。

この問題を解決するには、ストアド プロシージャを使用できます。ストアド プロシージャは、プリペアド ステートメントと OUT パラメータを利用して値を返すことができます。

動的に指定されたテーブルから名前を取得できるストアド プロシージャの例を次に示します。

CREATE PROCEDURE getName
(IN tableName VARCHAR(50), IN myId INT(11), OUT myName VARCHAR(50))
BEGIN

  SET @GetName =
    CONCAT('SELECT name INTO @var1 FROM ', tableName, ' WHERE>
ログイン後にコピー

プロシージャを使用するには、IN パラメータはテーブル名と ID で設定され、OUT パラメータは名前の取得に使用されます。

SET @tableName = 'tbl';
SET @myId = 1005;
SET @name = NULL;
CALL getName(@tableName, @myId, @name);
SELECT @name;
ログイン後にコピー

以上がSQL 関数内で動的に名前が付けられたテーブルにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート