ホームページ >データベース >mysql チュートリアル >PL/pgSQL を使用して PostgreSQL で複数のフィールドを単一のレコードとして取得する方法

PL/pgSQL を使用して PostgreSQL で複数のフィールドを単一のレコードとして取得する方法

Barbara Streisand
Barbara Streisandオリジナル
2025-01-05 05:49:43643ブラウズ

How to Retrieve Multiple Fields as a Single Record in PostgreSQL Using PL/pgSQL?

PL/pgSQL を使用して PostgreSQL で複数のフィールドをレコードとして取得する

データベースの操作を行う場合、多くの場合、複数のテーブルからデータをフェッチし、それを次のように表示する必要があります。統一された記録。 PostgreSQL では、PL/pgSQL の RECORD タイプを使用してこの機能を許可し、開発者が異なるテーブルからフィールドを単一レコード内のフィールドとして取得できるようにします。

異なるテーブルからのフィールドを単一のレコードとして返す

To複数のテーブルからフィールドを単一レコードのフィールドとして取得する場合、PL/pgSQL は RECORD タイプを使用します。例の修正版は次のとおりです。

CREATE OR REPLACE FUNCTION get_object_fields(name text)
  RETURNS RECORD AS $$
BEGIN
  -- Fetch fields f1, f2, and f3 from table t1
  -- Fetch fields f4, f5 from table t2
  -- Fetch fields f6, f7, and f8 from table t3

  -- Create a record to store the fetched fields
  RETURN RECORD(
    f1 TEXT,
    f2 TEXT,
    f3 TEXT,
    f4 TEXT,
    f5 TEXT,
    f6 TEXT,
    f7 TEXT,
    f8 TEXT
  );
END
$$ language plpgsql;

単一テーブルの複数のフィールドを持つ行の処理

特定のフィールドが単一テーブル内の複数の行にまたがって格納される可能性がある状況に対処する場合、 RECORD タイプは引き続き効果的に使用できます。 「user」テーブルを使用した例では、コードを次のように変更できます。

CREATE OR REPLACE FUNCTION get_two_users_from_school(schoolid int)
  RETURNS my_type AS $$
DECLARE
  result my_type;
  temp_result RECORD;
  user1 RECORD;
  user2 RECORD;
BEGIN
  SELECT id, name INTO temp_result FROM user WHERE school_id = schoolid LIMIT 2;

  -- Split the fetched rows into individual user records
  user1.user1_id := temp_result.id;
  user1.user1_name := temp_result.name;

  -- Handle the second row if available
  IF FOUND THEN
    user2.user2_id := temp_result.id;
    user2.user2_name := temp_result.name;
  END IF;

  -- Return the combined user record
  result.user1_id := user1.user1_id;
  result.user1_name := user1.user1_name;
  result.user2_id := user2.user2_id;
  result.user2_name := user2.user2_name;

  RETURN result;
END
$$ language plpgsql;

多態的な結果の処理

多態的な結果を返すには CREATE TYPE の使用が合理的であるように思えるかもしれませんが、PL/ pgSQL は、より柔軟で堅牢なアプローチを提供します。 RECORD 型を悪用すると、入力に基づいてさまざまな数の列を返すことができるため、オプションのエラー メッセージや追加情報の処理に適しています。

次に例を示します:

CREATE FUNCTION test_ret(a TEXT, b TEXT) RETURNS RECORD AS $$
DECLARE
  ret RECORD;
BEGIN
  IF LENGTH(a) < LENGTH(b) THEN
    ret := (TRUE, a || b, 'a shorter than b');
  ELSE
    ret := (FALSE, b || a);
  END IF;
  RETURN ret;
END;
$$ LANGUAGE plpgsql;

この関数は、入力に応じて 2 つまたは 3 つの列を動的に返し、成功ステータスやオプションのエラー メッセージを返すなど、さまざまなシナリオに使用できます。

以上がPL/pgSQL を使用して PostgreSQL で複数のフィールドを単一のレコードとして取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。