recherche
Maisonbase de donnéestutoriel mysqlComment renvoyer plusieurs champs sous la forme d'un seul enregistrement dans PostgreSQL à l'aide de PL/pgSQL ?

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

Renvoi de plusieurs champs sous forme d'enregistrement dans PostgreSQL avec PL/pgSQL

Dans PL/pgSQL, création d'une fonction qui renvoie plusieurs champs de différents Les tables en tant qu'enregistrement unique peuvent être obtenues via le type RECORD. Voici comment procéder :

Type RECORD

Déclarez un type RECORD qui définit les champs que vous souhaitez renvoyer. Par exemple :

CREATE TYPE person AS (
  name text,
  age integer,
  city text
);

Interrogation de différentes tables

Dans votre fonction PL/pgSQL, utilisez des requêtes pour récupérer les champs de différentes tables. Par exemple, si vous avez des tables d'utilisateurs, d'adresses et de villes, vous pouvez écrire :

SELECT u.name, u.age, a.city
FROM users AS u
JOIN addresses AS a ON u.address_id = a.id
WHERE u.user_id = @user_id;

Stockage des résultats de requête

Stocker les résultats de la requête dans une variable d'enregistrement . Le type RECORD permet d'accéder aux champs par nom de colonne :

DECLARE result person;
SELECT u.name, u.age, a.city INTO result;

Renvoyer l'enregistrement

Enfin, renvoyer l'enregistrement résultat :

RETURN result;

Gestion des résultats irréguliers

Si vous pouvez récupérer un numéro incohérent de lignes de différentes tables, utilisez la fonction coalesce() pour fournir des valeurs de secours :

SELECT
  coalesce(u.name, 'Unknown'),
  coalesce(u.age, 0),
  coalesce(a.city, 'N/A')
INTO result;

Exemple avec sous-requête

Si les données que vous devez renvoyer sont stockées sous forme de lignes séparées dans une seule table, utilisez une sous-requête :

CREATE FUNCTION get_two_users_from_school(schoolid int)
  RETURNS my_type AS $$
DECLARE
  result my_type;
BEGIN
  -- Select first two users from school
  SELECT id, name
  FROM user
  WHERE school_id = schoolid
  ORDER BY id
  LIMIT 2
  INTO result;
RETURN result;
END
$$ language plpgsql;

Cette approche vous permet d'"aplatir" les lignes en un structure d'enregistrement unique.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Comment abandonner ou modifier une vue existante dans MySQL?Comment abandonner ou modifier une vue existante dans MySQL?May 16, 2025 am 12:11 AM

Tadropaviewinmysql, utilisez "dropVieVieFexistView_name;" andtomodifyAview, utilisez "CreateOrrePlaceViewView_NameasSelect ...". WHENDROPPINGAVIEW, Considérez les dépenses et utilise "showCreateViewView_name;

Vues MySQL: quels modèles de conception puis-je utiliser avec?Vues MySQL: quels modèles de conception puis-je utiliser avec?May 16, 2025 am 12:10 AM

MysqlViewScaneffectivelyulizeSesIgnPatternslikEadapter, décorateur, usine, andobserver.1) adapterpatternadaptsdatafromdifferentTablesIntoaunifiedView.

Quels sont les avantages de l'utilisation de vues dans MySQL?Quels sont les avantages de l'utilisation de vues dans MySQL?May 16, 2025 am 12:09 AM

VuesInmysqLareBeneficialForsImpliftifiedComplexQueries, améliingSecUrit, assurant la dataconsistence et optimisation

Comment puis-je créer une vue simple dans MySQL?Comment puis-je créer une vue simple dans MySQL?May 16, 2025 am 12:08 AM

ToCreateasImpleViewInMysQl, usethCreatEViewstatement.1) définietheViewwithCreateEViewView_Nameas.2)

MySQL Créer une instruction utilisateur: Exemples et erreurs courantesMySQL Créer une instruction utilisateur: Exemples et erreurs courantesMay 16, 2025 am 12:04 AM

ToCreateUsersinmysql, usethcreateuserstatement.1) ForalocalUser: CreateUser'LocAlUser '@' localhost'identifiedby'securepassword '; 2) forareMoteUser: CreateUser'RemoteUser' @ '%' identifiéBy'strongPassword '; 3)

Quelles sont les limites de l'utilisation de vues dans MySQL?Quelles sont les limites de l'utilisation de vues dans MySQL?May 14, 2025 am 12:10 AM

MySQLViewShavelimitations: 1) Theydon'tsupportalLSQLOPERations, restreignantDatamanipulation à travers la vue

Sécuriser votre base de données MySQL: ajouter des utilisateurs et accorder des privilègesSécuriser votre base de données MySQL: ajouter des utilisateurs et accorder des privilègesMay 14, 2025 am 12:09 AM

La bonne gestion de la gestion de la direction

Quels facteurs influencent le nombre de déclencheurs que je peux utiliser dans MySQL?Quels facteurs influencent le nombre de déclencheurs que je peux utiliser dans MySQL?May 14, 2025 am 12:08 AM

MySQLDOES NONTIMPOSEAHARDLIMITORSTRIGRERS, BUTPRATICALFACTORSEDERTERMINETHEIREFFECTYUSE: 1) ServerConfiguration ImpactStriggerManagement; 2) ComplexTriggersInCreasgeSystemload; 3) LargerTableSlowtriggerPerformance; 4) HighCunCurrencyCanCauseTr fichestring; 5) M) M

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
<🎜> Obscur: Expedition 33 - Comment obtenir des catalyseurs de chrome parfaits
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel