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

PL/pgSQLを使用してPostgreSQLで複数のテーブルフィールドを単一のレコードとして返す方法は?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-03 10:55:40529ブラウズ

How to Return Multiple Table Fields as a Single Record in PostgreSQL using PL/pgSQL?

PL/pgSQL を使用した PostgreSQL のレコードとして複数のテーブル フィールドを返す

PL/pgSQL を使用する場合、複数のテーブルから複数のフィールドを返すレコードとしては、RECORD データ型を使用することで実現できます。これにより、さまざまなデータ型のフィールドを保持できる複合データ型を作成できます。

サンプル コード

追加の複雑さに対処する、次の変更された例を考えてみましょう。テーブル内の個別の行からフィールドを取得する方法:

CREATE TABLE user (id int, school_id int, name varchar(32));

CREATE TYPE my_type AS (
  user1_id   int,
  user1_name varchar(32),
  user2_id   int,
  user2_name varchar(32)
);

CREATE OR REPLACE FUNCTION get_two_users_from_school(schoolid int)
  RETURNS my_type AS $$
DECLARE
  result my_type;
  temp_result user;
BEGIN
  SELECT id, name INTO temp_result FROM user WHERE school_id = schoolid ORDER BY id ASC LIMIT 2;
  
  result.user1_id := temp_result[1].id;
  result.user1_name := temp_result[1].name;
  
  IF temp_result[2].id IS NOT NULL THEN
    result.user2_id := temp_result[2].id;
    result.user2_name := temp_result[2].name;
  END IF;
  
  RETURN result;
END
$$ language plpgsql;

この例では、 get_two_users_from_school 関数は、user1_id、user1_name、user2_id、および user2_name の 4 つのフィールドを持つ my_type レコードを返します。ユーザー テーブルからデータを取得して整理し、行を単一のまとまりのあるレコードに平坦化します。

動的レコード構造

返されるレコードは厳密には一致しないことに注意してください。特定の数のフィールドに制限されます。データベースから取得したデータに基づいて、任意の数のフィールドを返すことができます。

使用法

この関数を使用するには、次のクエリを実行できます。

SELECT * FROM get_two_users_from_school(123);

これにより、指定された学校 ID からユーザーの詳細を含むレコードが返されます。

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

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