Échantillonnage de table
L'échantillonnage de table vous permet d'interroger des sous-ensembles aléatoires de données provenant de grandes tables BigQuery. L'échantillonnage renvoie divers enregistrements tout en évitant les coûts liés à l'analyse et au traitement d'une table entière.
Utiliser l'échantillonnage de table
Pour utiliser l'échantillonnage de table dans une requête, incluez la
clause
TABLESAMPLE
. Par exemple, la requête suivante sélectionne environ 10 % des données
d'une table :
SELECT * FROM dataset.my_table TABLESAMPLE SYSTEM (10 PERCENT)
Contrairement à la clause LIMIT
, TABLESAMPLE
renvoie un sous-ensemble aléatoire de données d'une
table. De plus, BigQuery ne met pas en cache les résultats des requêtes
incluant une clause TABLESAMPLE
. Par conséquent, la requête peut renvoyer des résultats différents à chaque
fois.
Vous pouvez combiner la clause TABLESAMPLE
avec d'autres conditions de sélection. L'exemple
suivant présente environ 50 % de la table, puis applique une clause
WHERE
:
SELECT *
FROM dataset.my_table TABLESAMPLE SYSTEM (50 PERCENT)
WHERE customer_id = 1
L'exemple suivant combine une clause TABLESAMPLE
avec une clause JOIN
:
SELECT *
FROM dataset.table1 T1 TABLESAMPLE SYSTEM (10 PERCENT)
JOIN dataset.table2 T2 TABLESAMPLE SYSTEM (20 PERCENT) USING (customer_id)
Pour les tables plus petites, si vous joignez deux échantillons et qu'aucune des lignes échantillonnées ne remplit la condition de jointure, vous recevrez peut-être un résultat vide.
Vous pouvez spécifier le pourcentage sous la forme d'un paramètre de requête. L'exemple suivant montre comment transmettre le pourcentage à une requête à l'aide de l'outil de ligne de commande bq :
bq query --use_legacy_sql=false --parameter=percent:INT64:29 \
'SELECT * FROM `dataset.my_table` TABLESAMPLE SYSTEM (@percent PERCENT)`
Les tables BigQuery sont organisées en blocs de données. La clause TABLESAMPLE
consiste à sélectionner de manière aléatoire un pourcentage de blocs de données dans la table
et à lire toutes les lignes des blocs sélectionnés. La précision de l'échantillonnage
est limitée par le nombre de blocs de données.
En règle générale, BigQuery divise les tables ou les partitions de tables en blocs
si leur taille est supérieure à environ 1 Go. Les tables plus petites peuvent être constituées d'un seul
bloc de données. Dans ce cas, la clause TABLESAMPLE
lit la table entière. Si
le pourcentage d'échantillonnage est supérieur à zéro et que la table n'est pas vide,
l'échantillonnage de la table renvoie toujours certains résultats.
Les blocs peuvent avoir des tailles différentes, de sorte que la fraction exacte des lignes échantillonnées
peut varier. Si vous souhaitez échantillonner des lignes individuelles plutôt que des blocs de données,
vous pouvez utiliser une clause WHERE rand() < K
à la place. Cependant, cette approche nécessite que
BigQuery analyse l'ensemble de la table. Pour réduire les coûts tout en
bénéficiant de l'échantillonnage au niveau des lignes, vous pouvez combiner ces deux techniques.
L'exemple suivant lit environ 20 % des blocs de données du stockage, puis sélectionne de manière aléatoire 10 % des lignes de ces blocs :
SELECT * FROM dataset.my_table TABLESAMPLE SYSTEM (20 PERCENT)
WHERE rand() < 0.1
Tables externes
Vous pouvez utiliser la clause TABLESAMPLE
avec des tables externes qui stockent les données dans un
ensemble de fichiers. BigQuery échantillonne un sous-ensemble des fichiers
externes auxquels la table fait référence. Pour certains formats de fichiers, BigQuery
peut diviser des fichiers individuels en blocs pour l'échantillonnage. Certaines données externes, telles que celles contenues dans Google Sheets, se composent d'un fichier unique échantillonné comme un bloc de données.
Échantillonnage à partir du stockage optimisé en écriture
Si vous utilisez l'échantillonnage de table avec des insertions en flux continu, BigQuery échantillonne les données du stockage optimisé pour l'écriture. Dans certains cas, toutes les données du stockage optimisé en écriture sont représentées sous la forme d'un bloc unique. Dans ce cas, toutes les données stockées dans l'espace de stockage optimisé en écriture apparaissent dans les résultats, ou aucune.
Tables partitionnées et en cluster
Le partitionnement et le clustering produisent des blocs dans lesquels toutes les lignes d'un bloc spécifique ont la même clé de partitionnement ou possèdent des attributs de clustering avec des valeurs proches. Par conséquent, les ensembles d'échantillons de ces tables ont tendance à être plus biaisés que les ensembles d'échantillons de tables non partitionnées et non mises en cluster.
Limites
- Une table échantillonnée ne peut apparaître qu'une seule fois dans une instruction de requête. Cette restriction inclut les tables référencées dans les définitions de vue.
- L'échantillonnage des données à partir des vues n'est pas possible.
- L'échantillonnage des résultats des sous-requêtes ou des appels de fonction de valeur de table n'est pas possible.
- L'échantillonnage à partir d'une analyse de tableau, tel que le résultat de l'appel de l'opérateur
UNNEST
, n'est pas compatible. - L'échantillonnage dans une sous-requête
IN
n'est pas possible. - L'échantillonnage des tables avec la sécurité au niveau des lignes n'est pas accepté.
Tarifs de l'échantillonnage de table
Si vous utilisez la facturation à la demande,
la lecture des données échantillonnées vous est facturée. BigQuery ne met pas
en cache les résultats d'une requête incluant une clause TABLESAMPLE
. Par conséquent, chaque
exécution engendre des coûts de lecture des données de l'espace de stockage.