Tableau 9.51 montre les opérateurs spécialisés disponibles pour les types tableau. En plus de ces derniers, les opérateurs habituels de comparaison montrés dans Tableau 9.1 sont disponibles pour les tableaux. Les opérateurs de comparaison comparent le contenu des tableaux éléments par éléments, en utilisant la fonction de comparaison B-tree par défaut pour le type de données de l'élément, et trient en se basant sur la première différence rencontrée. Dans les tableaux multi-dimensionnels, les éléments sont visités dans l'ordre des lignes (le dernier indice varie plus rapidement). Si les contenus de deux tableaux sont identiques mais que leur dimension est différente, la première différence dans l'information de dimension détermine l'ordre de tri. (Ceci change des versions de PostgreSQL antérieures à la 8.2 : les anciennes versions penseront que deux tableaux de même contenu sont identiques, même si le nombre de dimensions ou l'étendu des indices est différent.)
Tableau 9.51. Opérateurs de tableau
Opérateur Description Exemple(s) |
---|
Est-ce que le premier tableau contient le second, autrement dit,
est-ce que chaque élément apparaissant dans le deuxième tableau est
égal à un élément du premier tableau ? (les duplicats ne sont pas
traités spécialement, donc
|
Est-ce que le premier tableau est contenu par le second ?
|
Est-ce que les tableaux se surchargent, autrement dit ont des éléments en commun ?
|
Concatène les deux tableaux. Concaténer un tableau NULL ou un tableau vide est une opération vide ; sinon les tableaux doivent avoir le même nombre de dimensions (comme illustré dans le premier exemple) ou différer de 1 dans le nombre de dimensions (comme illustré dans le second exemple).
|
Concatène un élément au début d'un tableau (qui doit être vide ou à une dimension).
|
Concatène un élément à la fin d'un tableau (qui doit être vide ou à une dimension).
|
Voir Section 8.15 pour plus de détails sur le comportement des opérateurs pour tableau. Voir Section 11.2 pour plus de détails sur les opérateurs supportant des opérations indexées.
Tableau 9.52 montre les fonctions disponibles pour utilisation avec des types tableau. Voir Section 8.15 pour plus d'informations et d'exemples sur l'utilisation de ces fonctions.
Tableau 9.52. Fonctions tableau
Fonction Description Exemple(s) |
---|
Ajoute un élément à la fin d'un tableau (identique à l'opérateur
|
Concatène deux tableaux (identique à l'opérateur
|
Renvoie une représentation textuelle des dimensions du tableau.
|
Renvoie un tableau rempli de copies de la valeur donnée, ayant les
dimensions de longueurs spécifiés par le deuxième argument. Le
troisième argument optionnel fournit des valeurs de limite basse pour
chaque dimension (qui vaut par défaut
|
Renvoie la longueur de la dimension réclamée du tableau. (Renvoie NULL à la place de 0 pour des dimensions vides ou manquantes.)
|
Renvoie la limite basse de la dimension réclamée du tableau.
|
Renvoie le nombre de dimensions du tableau.
|
Renvoie l'indice de la première occurence du second argument dans le
tableau, ou
|
Renvoie un tableau des indices de toutes les occurrences du deuxième
argument dans le tableau donné comme premier argument. Le tableau doit
être à une dimension. Les comparaisons sont effectuées en utilisant
les sémantiques de
|
Ajoute un élément au début d'un tableau (identique à l'opérateur
|
Supprime tous les éléments identiques à la valeur donnée à partir du
tableau. Le tableau doit être à une dimension. Les comparaisons sont
faites en utilisant les sémantiques de
|
Remplace chaque élément de tableau égal au second argument avec le troisième argument.
|
Convertit chaque élément de tableau en sa représentation textuelle, et
les concatène en les séparant par la chaîne
|
Renvoie la limite haute de la dimension demandée du tableau.
|
Renvoie le nombre total d'éléments dans le tableau, ou 0 si le tableau est vide.
|
Divise la chaîne
|
Étend un tableau en un ensemble de lignes. Les éléments du tableau sont lus dans l'ordre de stockage.
1 2
foo bar baz quux
|
Étend plusieurs tableaux (potentiellement de types de données
différents) en un ensemble de lignes. Si les tableaux ne sont pas de la
même longueur, alors les plus courts sont alignés avec des
a | b ---+----- 1 | foo 2 | bar | baz
|
Il existe deux différences dans le comportement de
string_to_array
pour les versions de
PostgreSQL antérieures à la 9.1. Tout d'abord,
elle renverra un tableau vide (zéro élément) plutôt qu'un
NULL
quand la chaîne en entrée est de taille zéro.
Ensuite, si la chaîne délimiteur est NULL
, la fonction
divise l'entrée en caractères individuels, plutôt que de renvoyer
NULL
comme avant.
Voir aussi Section 9.21 sur la fonction d'agrégat
array_agg
pour une utilisation avec les tableaux.