recherche
Maisonbase de donnéestutoriel mysqlComment puis-je transmettre plusieurs valeurs à un seul paramètre de fonction dans PostgreSQL ?

How Can I Pass Multiple Values to a Single Function Parameter in PostgreSQL?

Utilisez les paramètres VARIADIC pour transmettre plusieurs valeurs dans un seul paramètre

Créer une fonction avec des paramètres VARIADIC

Afin de transmettre plusieurs valeurs à un seul paramètre, vous pouvez utiliser le type de données VARIADIC. Cela vous permet de spécifier un tableau de valeurs pour le paramètre. Modifiez la fonction suivante pour accepter un paramètre VARIADIC nommé job_ids :

CREATE OR REPLACE FUNCTION test_var(VARIADIC job_ids int[])
RETURNS TABLE (
  job_id int,
  job_reference int,
  job_job_title text,
  job_status text
) AS $$
BEGIN
  RETURN QUERY
  SELECT
    jobs.id,
    jobs.reference,
    jobs.job_title,
    ltrim(right(jobs.status, -2)) AS status  -- 使用right()函数改进字符串处理
  FROM
    jobs
  INNER JOIN
    company c ON c.id = jobs.id  -- 使用INNER JOIN改进查询效率
  WHERE
    jobs."DeleteFlag" = '0' AND
    c.DeleteFlag = '0' AND
    c.active = '1' AND
    (jobs.id = ANY(job_ids) OR job_ids = '{ -1 }') -- 简化条件判断
  ORDER BY
    jobs.job_title;
END;
$$ LANGUAGE plpgsql;

Fonction d'appel avec paramètres VARIADIC

Vous pouvez désormais appeler la fonction test_var en passant un tableau de valeurs au paramètre job_ids. Par exemple :

SELECT * FROM test_var('{270, 378}');

Cela renverra les données de travail avec les ID 270 et 378.

Améliorations des fonctions et suggestions supplémentaires

En plus d'utiliser le paramètre VARIADIC, vous pouvez également utiliser la fonction right() en combinaison avec une longueur négative pour couper les caractères au début de la chaîne, ce qui est plus rapide et plus simple que d'utiliser substring.

Assurez-vous également que le type de données de la colonne DeleteFlag est booléen et non texte. Cela garantit une comparaison et une efficacité correctes.

Enfin, la fonction f_test fournie dans la réponse démontre une fonction SQL concise qui évite l'utilisation de PL/pgSQL et résout ces problèmes. Il est recommandé de choisir la méthode de mise en œuvre des fonctions appropriée en fonction des besoins réels.

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
Types de chaînes MySQL: stockage, performances et meilleures pratiquesTypes de chaînes MySQL: stockage, performances et meilleures pratiquesMay 10, 2025 am 12:02 AM

MysqlStringTypeSimpactStorageAndPerformanceSfollows: 1) Charisfixed-Length, AlwaysusingTheSameStoragespace, qui, de manière morépace-efficace sans espace.

Comprendre les types de chaînes MySQL: varchar, texte, char, et plus encoreComprendre les types de chaînes MySQL: varchar, texte, char, et plus encoreMay 10, 2025 am 12:02 AM

MysqlstringTypeSincludevarchar, text, char, énum, ​​andset.1) varcharinsversatileforvariable-LengthstringSuptoSpecifiedImmit.2)

Quels sont les types de données de chaîne dans MySQL?Quels sont les types de données de chaîne dans MySQL?May 10, 2025 am 12:01 AM

MysqloffersvariousStringDatatypes: 1) Charforfixed-LengthStrings, 2) varcharforvariable-LengthText, 3) binaryandvarbinaryforbinarydata, 4) blobandtextforlatedata, and5) enumandsetfor.

Comment accorder des autorisations aux nouveaux utilisateurs de MySQLComment accorder des autorisations aux nouveaux utilisateurs de MySQLMay 09, 2025 am 12:16 AM

TOGRANTERMISSIMESTESTERSWMYSQLUSERS, SuivreTheSesteps: 1) AccessMysqlasauserwithSufficientPrivileges, 2) CreateEnewUserwithThereAserercommand, 3) UsethegrantCommandTospecifyPerMissionsLikEselect, insert, mise à jour, OrallegandSonSpecificaCificdataStAtAnSorables, et4), 4).

Comment ajouter des utilisateurs dans MySQL: un guide étape par étapeComment ajouter des utilisateurs dans MySQL: un guide étape par étapeMay 09, 2025 am 12:14 AM

ToaddUsersInmysqleffecativement et en résultant, suivez-vous: 1) UsethCreateAsTatement à AddanEwUser, spécifiant le dossier d'astron.

MySQL: ajout d'un nouvel utilisateur avec des autorisations complexesMySQL: ajout d'un nouvel utilisateur avec des autorisations complexesMay 09, 2025 am 12:09 AM

ToaddanewUserwithComplexPermisessionsInmysql, suivi destiné: 1) Création sword ';. 2) GRANTREADACCESSTOALLTABLESSIn'MYDATABASE'WithGrantsElectonMyDatabase.To'newuser' @ 'LocalHost';. 3) GRANTWRITEACESSTO '

MySQL: Types et collations de données de chaîneMySQL: Types et collations de données de chaîneMay 09, 2025 am 12:08 AM

Les types de données de chaîne dans MySQL incluent Char, Varchar, Binary, Varbinary, Blob et Text. Les collations déterminent la comparaison et le tri des chaînes. 1. Char convient aux chaînes de longueur fixe, Varchar convient aux chaînes de longueur variable. 2.Binara et varbinaire sont utilisés pour les données binaires, et Blob et le texte sont utilisés pour les données de grandes objets. 3. Les règles de tri telles que UTF8MB4_UNICODE_CI ignorent les caractéristiques supérieures et inférieures et conviennent aux noms d'utilisateurs; UTF8MB4_BIN est sensible à la casse et convient aux champs qui nécessitent une comparaison précise.

MySQL: Quelle longueur dois-je utiliser pour Varchars?MySQL: Quelle longueur dois-je utiliser pour Varchars?May 09, 2025 am 12:06 AM

La meilleure sélection de la longueur de la colonne MySqlvarchar doit être basée sur l'analyse des données, considérer la croissance future, évaluer les impacts des performances et les exigences des ensembles de caractères. 1) Analyser les données pour déterminer les longueurs typiques; 2) Réserver l'espace d'expansion future; 3) Faites attention à l'impact de grandes longueurs sur les performances; 4) Considérez l'impact des ensembles de caractères sur le stockage. Grâce à ces étapes, l'efficacité et l'évolutivité de la base de données peuvent être optimisées.

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
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

PhpStorm version Mac

PhpStorm version Mac

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

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

SublimeText3 version Mac

SublimeText3 version Mac

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

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel