


Comment corriger l'erreur PostgreSQL 42601 : « une liste de définitions de colonnes est requise pour les fonctions renvoyant « enregistrement » » ?
Jan 05, 2025 pm 03:10 PM<h2>PostgreSQL : ERREUR : 42601 : une liste de définitions de colonnes est requise pour les fonctions renvoyant "record"</h2>
L'erreur "une colonne une liste de définitions est requise pour les fonctions renvoyant « enregistrement » » indique qu'une fonction définie pour renvoyer un type de données d'enregistrement ne contient pas les noms de colonnes et les types de données dans sa déclaration de retour. Pour résoudre cette erreur, spécifiez les définitions de colonnes dans la clause RETURNING ou utilisez RETURNS SETOF <record_type>.
Comme démontré dans le code suivant, vous pouvez définir les noms de colonnes et les types de données dans la clause RETURNING :
CREATE OR REPLACE FUNCTION get_user_by_username(_username text , _online bool DEFAULT false) RETURNS TABLE ( user_id int , user_name varchar , last_activity timestamptz ) LANGUAGE plpgsql AS $func$ BEGIN IF _online THEN RETURN QUERY UPDATE users u SET last_activity = current_timestamp -- ts with time zone WHERE u.user_name = _username RETURNING u.user_id , u.user_name , u.last_activity; ELSE RETURN QUERY SELECT u.user_id , u.user_name , u.last_activity FROM users u WHERE u.user_name = _username; END IF; END $func$;
Vous pouvez également utiliser RETURNS SETOF <record_type> pour renvoyer un ensemble d'enregistrements, où <record_type> est un type composite qui représente la structure des données renvoyées. Par exemple :
CREATE OR REPLACE FUNCTION get_user_by_username3(_username text , _online bool DEFAULT false) RETURNS TABLE ( users_row users , custom_addition text ) LANGUAGE plpgsql AS $func$ BEGIN IF _online THEN RETURN QUERY UPDATE users u SET last_activity = current_timestamp -- ts with time zone WHERE u.user_name = _username RETURNING u -- whole row , u.user_name || u.user_id; ELSE RETURN QUERY SELECT u, u.user_name || u.user_id FROM users u WHERE u.user_name = _username; END IF; END $func$;
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Réduisez l'utilisation de la mémoire MySQL dans Docker

Comment modifier une table dans MySQL en utilisant l'instruction ALTER TABLE?

Comment résoudre le problème de MySQL ne peut pas ouvrir la bibliothèque partagée

Exécutez MySQL dans Linux (avec / sans conteneur Podman avec phpmyadmin)

Exécuter plusieurs versions MySQL sur macOS: un guide étape par étape

Comment sécuriser MySQL contre les vulnérabilités communes (injection SQL, attaques par force brute)?

Quels sont les outils de GUI MySQL populaires (par exemple, MySQL Workbench, PhpMyAdmin)?
