Stocker les requêtes fréquemment utilisées sous forme de colonnes de tableau ?
Requête :
Considérez la requête PostgreSQL suivante :
<code class="language-sql">SELECT <col>, <col> , (SELECT sum(<colx>) FROM <othertable> WHERE <otherforeignkeycol> = <thiskeycol>) AS <col> FROM <tbl>;</code>
Cette sous-requête reste la même pour plusieurs requêtes. Est-il possible de stocker cette sous-requête en tant que pseudo-colonne d'une table afin de pouvoir sélectionner facilement une colonne du tableau A qui représente la somme des colonnes du tableau B en fonction d'une relation d'enregistrement ?
Réponse :
1. Vue
Créer une vue est une solution efficace qui vous permet de définir une table virtuelle avec la sous-requête requise comme l'une de ses colonnes.
2. Champs calculés (colonnes générées par le stockage)
Les colonnes générées par le stockage introduites dans PostgreSQL 11 répondent à vos exigences. Ceux-ci vous permettent de définir une colonne calculée dynamiquement en fonction des valeurs d'autres colonnes (y compris les sous-requêtes).
Implémentation à l'aide de champs calculés :
Considérez la forme suivante :
<code class="language-sql">CREATE TABLE tbl_a (a_id int, col1 int, col2 int); CREATE TABLE tbl_b (b_id int, a_id int, colx int);</code>
Créez un champ calculé à l'aide d'une fonction :
<code class="language-sql">CREATE FUNCTION col3(a_id INT) RETURNS int8 LANGUAGE sql STABLE AS $func$ SELECT sum(colx) FROM tbl_b b WHERE b.a_id = $func$;</code>
Vous pouvez désormais interroger :
<code class="language-sql">SELECT a_id, col1, col2, col3(a_id) FROM tbl_a;</code>
Instructions :
Les champs calculés simulent une sous-requête en fournissant la valeur d'une colonne spécifiée en fonction de la ligne actuelle du tableau. Accédez aux champs calculés à l'aide de la notation attributaire (par exemple, col3(a_id)
). Cette technique permet une récupération dynamique des valeurs calculées et maintient la compatibilité avec les requêtes SELECT*. Notez que la définition de la fonction a été modifiée ici, en utilisant a_id
directement comme paramètre, évitant ainsi l'utilisation de l'écriture d'enregistrements et simplifiant la requête.
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!