Passer au contenu principal
La fonctionnalité Query API Endpoints vous permet de créer un endpoint d’API directement à partir de n’importe quelle requête SQL enregistrée dans la console ClickHouse Cloud. Vous pourrez accéder à ces endpoints d’API via HTTP afin d’exécuter vos requêtes enregistrées sans avoir à vous connecter à votre service ClickHouse Cloud à l’aide d’un driver natif.

Prérequis

Avant de continuer, assurez-vous d’avoir :
  • une clé API avec les autorisations appropriées
  • un rôle Admin dans la Console
Vous pouvez suivre ce guide pour créer une clé API si vous n’en avez pas encore.
Autorisations minimalesPour interroger un endpoint d’API, la clé API doit disposer du rôle d’organisation Member avec l’accès au service Query Endpoints. Le rôle de base de données est configuré lors de la création de l’endpoint.
1

Créer une requête enregistrée

Si vous avez déjà une requête enregistrée, vous pouvez ignorer cette étape.Ouvrez un nouvel onglet de requête. À des fins de démonstration, nous utiliserons le jeu de données YouTube, qui contient environ 4,5 milliards d’enregistrements. Suivez les étapes de la section “Create table” pour créer la table sur votre service Cloud et y insérer des données.
Limiter le nombre de lignes avec LIMITLe tutoriel sur le jeu de données d’exemple insère un volume important de données — 4,65 milliards de lignes — ce qui peut prendre un certain temps. Pour ce guide, nous recommandons d’utiliser la clause LIMIT afin d’insérer un plus petit volume de données, par exemple 10 millions de lignes.
À titre d’exemple, nous allons renvoyer les 10 comptes ayant publié des vidéos avec la moyenne de vues par vidéo la plus élevée pour un paramètre year saisi par l’utilisateur.
WITH sum(view_count) AS view_sum,
  round(view_sum / num_uploads, 2) AS per_upload
SELECT
  uploader,
  count() AS num_uploads,
  formatReadableQuantity(view_sum) AS total_views,
  formatReadableQuantity(per_upload) AS views_per_video
FROM
  youtube
WHERE
  toYear(upload_date) = {year: UInt16}
GROUP BY uploader
ORDER BY per_upload desc
  LIMIT 10
Notez que cette requête contient un paramètre (year), mis en évidence dans l’extrait ci-dessus. Vous pouvez spécifier des paramètres de requête à l’aide de { } avec le type du paramètre. L’éditeur de requêtes de la console SQL détecte automatiquement les expressions de paramètres de requête ClickHouse et fournit un champ de saisie pour chaque paramètre.Exécutons rapidement cette requête pour vérifier qu’elle fonctionne en spécifiant l’année 2010 dans la zone de saisie des variables de requête située à droite de l’éditeur SQL :Ensuite, enregistrez la requête :Vous trouverez plus d’informations sur les requêtes enregistrées dans la section “Saving a query”.
2

Configuration de l’endpoint d’API de requête

Les endpoints d’API de requête peuvent être configurés directement depuis la vue de requête en cliquant sur le bouton Share, puis en sélectionnant API Endpoint. Il vous sera demandé de préciser quelles clés API doivent pouvoir accéder à l’endpoint :Après avoir sélectionné une clé API, il vous sera demandé de :
  • Sélectionner le rôle de base de données qui sera utilisé pour exécuter la requête (Full access, Read only ou Create a custom role)
  • Spécifier les domaines autorisés pour le partage de ressources entre origines (CORS)
Après avoir sélectionné ces options, l’endpoint d’API de requête sera automatiquement provisionné.Un exemple de commande curl s’affichera afin que vous puissiez envoyer une requête de test :La commande curl affichée dans l’interface est reproduite ci-dessous pour plus de commodité :
curl -H "Content-Type: application/json" -s --user '<key_id>:<key_secret>' '<API-endpoint>?format=JSONEachRow&param_year=<value>'
3

Paramètres de l’API de requête

Les paramètres d’une requête peuvent être spécifiés avec la syntaxe {parameter_name: type}. Ces paramètres seront automatiquement détectés et l’exemple de payload de requête contiendra un objet queryVariables vous permettant de transmettre ces paramètres.
4

Test et monitoring

Une fois un endpoint d’API de requête créé, vous pouvez vérifier son fonctionnement à l’aide de curl ou de tout autre client HTTP :Après l’envoi de votre première requête, un nouveau bouton devrait apparaître immédiatement à droite du bouton Share. En cliquant dessus, vous ouvrirez un panneau latéral contenant des données de monitoring sur la requête :

Détails d’implémentation

Cet endpoint exécute des requêtes sur vos Query API endpoints enregistrés. Il prend en charge plusieurs versions, des formats de réponse flexibles, des requêtes paramétrées et des réponses en streaming facultatives (version 2 uniquement). Endpoint :
GET /query-endpoints/{queryEndpointId}/run
POST /query-endpoints/{queryEndpointId}/run

Méthodes HTTP

MéthodeCas d’utilisationParamètres
GETRequêtes simples avec paramètresTransmettez les variables de requête via les paramètres d’URL (?param_name=value)
POSTRequêtes complexes ou lorsque le corps de la requête est utiliséTransmettez les variables de requête dans le corps de la requête (objet queryVariables)
Quand utiliser GET :
  • Requêtes simples sans données imbriquées complexes
  • Les paramètres peuvent être facilement encodés dans l’URL
  • La mise en cache tire parti de la sémantique HTTP de GET
Quand utiliser POST :
  • Variables de requête complexes (tableaux, objets, chaînes longues)
  • Lorsque le corps de la requête est préférable pour des raisons de sécurité ou de confidentialité
  • Téléversement de fichiers en continu ou données volumineuses

Authentification

Obligatoire : Oui Méthode : Basic Auth avec OpenAPI Key/Secret Permissions : Permissions appropriées pour l’endpoint de requête

Configuration de la requête

Paramètres d’URL

ParamètreObligatoireDescription
queryEndpointIdOuiL’identifiant unique de l’endpoint de requête à exécuter

Paramètres de requête

ParamètreObligatoireDescriptionExemple
formatNonFormat de réponse (prend en charge tous les formats ClickHouse)?format=JSONEachRow
param_:nameNonVariables de requête si le corps de la requête est un flux. Remplacez `:name“ par le nom de votre variable?param_year=2024
request_timeoutNonDélai d’expiration de la requête en millisecondes (par défaut : 30000)?request_timeout=60000
:clickhouse_settingNonTout paramètre ClickHouse pris en charge?max_threads=8

En-têtes

En-têteObligatoireDescriptionValeurs
x-clickhouse-endpoint-versionNonSpécifie la version de l’endpoint1 ou 2 (par défaut : dernière version enregistrée)
x-clickhouse-endpoint-upgradeNonDéclenche la mise à niveau de la version de l’endpoint (à utiliser avec l’en-tête de version)1 pour mettre à niveau

Corps de la requête

Paramètres

ParamètreTypeObligatoireDescription
queryVariablesobjetNonVariables à utiliser dans la requête
formatchaîneNonFormat de réponse

Formats pris en charge

VersionFormats pris en charge
Version 2Tous les formats pris en charge par ClickHouse
Version 1 (limité)TabSeparated
TabSeparatedWithNames
TabSeparatedWithNamesAndTypes
JSON
JSONEachRow
CSV
CSVWithNames
CSVWithNamesAndTypes

Réponses

Succès

Statut : 200 OK La requête a bien été exécutée.

Codes d’erreur

Code d’étatDescription
400 Bad RequestLa requête est mal formée
401 UnauthorizedAuthentification manquante ou permissions insuffisantes
404 Not FoundL’endpoint de requête spécifié est introuvable

Bonnes pratiques de gestion des erreurs

  • Assurez-vous que des identifiants d’authentification valides sont inclus dans la requête
  • Validez queryEndpointId et queryVariables avant l’envoi
  • Mettez en place une gestion appropriée des erreurs avec des messages d’erreur adaptés

Mise à niveau des versions d’endpoint

Pour passer de la version 1 à la version 2 :
  1. Incluez l’en-tête x-clickhouse-endpoint-upgrade défini sur 1
  2. Incluez l’en-tête x-clickhouse-endpoint-version défini sur 2
Cela active l’accès aux fonctionnalités de la version 2, notamment :
  • La prise en charge de tous les formats ClickHouse
  • Le streaming des réponses
  • Des performances et fonctionnalités améliorées

Exemples

Requête de base

SQL du Query API Endpoint :
SELECT database, name AS num_tables FROM system.tables LIMIT 3;

Version 1

curl -X POST 'https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run' \
--user '<openApiKeyId:openApiKeySecret>' \
-H 'Content-Type: application/json' \
-d '{ "format": "JSONEachRow" }'

Version 2

curl 'https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run?format=JSONEachRow' \
--user '<openApiKeyId:openApiKeySecret>' \
-H 'x-clickhouse-endpoint-version: 2'
Réponse
{"database":"INFORMATION_SCHEMA","num_tables":"COLUMNS"}
{"database":"INFORMATION_SCHEMA","num_tables":"KEY_COLUMN_USAGE"}
{"database":"INFORMATION_SCHEMA","num_tables":"REFERENTIAL_CONSTRAINTS"}

Requête avec des paramètres de requête et la version 2 au format JSONCompactEachRow

SQL du Query API Endpoint :
SELECT name, database FROM system.tables WHERE match(name, {tableNameRegex: String}) AND database = {database: String};
curl 'https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run?format=JSONCompactEachRow&param_tableNameRegex=query.*&param_database=system' \
--user '<openApiKeyId:openApiKeySecret>' \
-H 'x-clickhouse-endpoint-version: 2'
Réponse
["query_cache", "system"]
["query_log", "system"]
["query_views_log", "system"]

Requête avec un Array dans les variables de requête qui insère des données dans une table

SQL de la table :
CREATE TABLE default.t_arr
(
    `arr` Array(Array(Array(UInt32)))
)
ENGINE = MergeTree
ORDER BY tuple()
SQL du Query API Endpoint :
INSERT INTO default.t_arr VALUES ({arr: Array(Array(Array(UInt32)))});
curl -X POST 'https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run' \
--user '<openApiKeyId:openApiKeySecret>' \
-H 'Content-Type: application/json' \
-H 'x-clickhouse-endpoint-version: 2' \
-d '{
  "queryVariables": {
    "arr": [[[12, 13, 0, 1], [12]]]
  }
}'

Requête avec le paramètre ClickHouse max_threads défini sur 8

SQL du Query API Endpoint :
SELECT * FROM system.tables;
curl 'https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run?max_threads=8' \
--user '<openApiKeyId:openApiKeySecret>' \
-H 'x-clickhouse-endpoint-version: 2'

Interroger et analyser la réponse sous forme de flux

SQL du Query API Endpoint :
SELECT name, database FROM system.tables;
async function fetchAndLogChunks(
  url: string,
  openApiKeyId: string,
  openApiKeySecret: string
) {
  const auth = Buffer.from(`${openApiKeyId}:${openApiKeySecret}`).toString(
    "base64"
  );

  const headers = {
    Authorization: `Basic ${auth}`,
    "x-clickhouse-endpoint-version": "2",
  };

  const response = await fetch(url, {
    headers,
    method: "POST",
    body: JSON.stringify({ format: "JSONEachRow" }),
  });

  if (!response.ok) {
    console.error(`HTTP error! Status: ${response.status}`);
    return;
  }

  const reader = response.body as unknown as Readable;
  reader.on("data", (chunk) => {
    console.log(chunk.toString());
  });

  reader.on("end", () => {
    console.log("Stream ended.");
  });

  reader.on("error", (err) => {
    console.error("Stream error:", err);
  });
}

const endpointUrl =
  "https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run?format=JSONEachRow";
const openApiKeyId = "<myOpenApiKeyId>";
const openApiKeySecret = "<myOpenApiKeySecret>";
// Exemple d'utilisation
fetchAndLogChunks(endpointUrl, openApiKeyId, openApiKeySecret).catch((err) =>
  console.error(err)
);
Sortie
> npx tsx index.ts
> {"name":"COLUMNS","database":"INFORMATION_SCHEMA"}
> {"name":"KEY_COLUMN_USAGE","database":"INFORMATION_SCHEMA"}
...
> Stream ended.

Insérer un flux de données provenant d’un fichier dans une table

Créez un fichier ./samples/my_first_table_2024-07-11.csv avec le contenu suivant :
"user_id","json","name"
"1","{""name"":""John"",""age"":30}","John"
"2","{""name"":""Jane"",""age"":25}","Jane"
SQL CREATE TABLE :
create table default.my_first_table
(
    user_id String,
    json String,
    name String,
) ENGINE = MergeTree()
ORDER BY user_id;
SQL du Query API Endpoint :
INSERT INTO default.my_first_table
cat ./samples/my_first_table_2024-07-11.csv | curl --user '<openApiKeyId:openApiKeySecret>' \
                                                   -X POST \
                                                   -H 'Content-Type: application/octet-stream' \
                                                   -H 'x-clickhouse-endpoint-version: 2' \
                                                   "https://console-api.clickhouse.cloud/.api/query-endpoints/<endpoint id>/run?format=CSV" \
                                                   --data-binary @-
Dernière modification le 25 juin 2026