Questions fréquentes
Ce document fournit des réponses aux questions fréquentes sur Query Service et fournit une liste des codes d’erreur courants lors de l’utilisation de Query Service. Pour toute question ou dépannage concernant les autres services d’Adobe Experience Platform, consultez le guide de dépannage d’Experience Platform.
La liste suivante de réponses aux questions fréquentes est divisée en plusieurs catégories :
Questions générales sur Query Service general
Cette section contient des informations sur les performances, les limites et les processus.
Puis-je désactiver la fonction de saisie automatique dans l’éditeur de Query Service ?
Pourquoi Query Editor ralentit-il parfois lorsque je tape une requête ?
Puis-je utiliser Postman pour l’API Query Service ?
Existe-t-il un nombre maximal de lignes renvoyées par une requête via l’interface utilisateur ?
Puis-je utiliser des requêtes pour mettre à jour des lignes ?
Existe-t-il une limite de taille des données pour la sortie obtenue à partir d’une requête ?
Comment contourner la limite du nombre de lignes de sortie d’une requête SELECT ?
Pour contourner la limite du nombre de lignes de sortie, appliquez « LIMIT 0 » dans la requête. Par exemple :
code language-sql |
---|
|
Comment empêcher mes requêtes d’expirer au bout de 10 minutes ?
Nous recommandons l’une ou plusieurs des solutions suivantes en cas d’expiration des requêtes.
- Convertissez la requête en requête CTAS et planifiez l’exécution. Vous pouvez planifier une exécution via l’interface utilisateur ou l’API.
- Exécutez la requête sur un bloc de données plus petit en appliquant des conditions de filtrage supplémentaires.
- Exécutez la commande EXPLAIN pour en savoir plus.
- Examinez les statistiques des données du jeu de données.
- Convertissez la requête en formulaire simplifié pour l’exécuter à nouveau à l’aide d’instructions préparées.
Y a-t-il un problème ou un impact sur les performances de Query Service si plusieurs requêtes s’exécutent simultanément ?
Puis-je utiliser des mots-clés réservés comme nom de colonne ?
ORDER
, GROUP BY
, WHERE
, DISTINCT
. Si vous souhaitez utiliser ces mots-clés, vous devez ajouter une séquence d’échappement à ces colonnes.Comment puis-je trouver un nom de colonne à partir d’un jeu de données hiérarchique ?
Les étapes suivantes décrivent comment afficher une vue tabulaire d’un jeu de données via l’interface utilisateur, y compris tous les champs et colonnes imbriqués dans un formulaire aplati.
- Une fois connecté(e) à Experience Platform, sélectionnez Jeux de données dans le volet de navigation de gauche de l’interface utilisateur pour accéder au tableau de bord Jeux de données.
- L’onglet pour Parcourir les jeux de données s’ouvre. Vous pouvez utiliser la barre de recherche pour affiner les options disponibles. Sélectionnez un jeu de données dans la liste.
- L’écran Activité des jeux de données s’affiche. Sélectionnez Prévisualiser le jeu de données pour ouvrir une boîte de dialogue du schéma XDM et une vue tabulaire des données aplaties du jeu de données sélectionné. Vous trouverez plus de détails dans la documentation sur la prévisualisation d’un jeu de données.
- Sélectionnez un champ du schéma pour afficher son contenu dans une colonne aplatie. Le nom de la colonne s’affiche au-dessus de son contenu sur le côté droit de la page. Vous devez copier le nom pour interroger ce jeu de données.
Consultez la documentation pour obtenir des conseils complets sur comment travailler avec des structures de données imbriquées à l’aide de Query Editor ou d’un client tiers.
Comment accélérer une requête sur un jeu de données contenant des tableaux ?
Pourquoi ma requête CTAS est-elle toujours en cours de traitement après de nombreuses heures alors qu’elle concerne peu de lignes ?
Si la requête a pris beaucoup de temps sur un très petit jeu de données, contactez le service clientèle.
Une requête peut être bloquée pendant le traitement pour plusieurs raisons. Pour déterminer la cause exacte, il faut effectuer une analyse approfondie au cas par cas. Contactez le service clientèle d’Adobe pour lancer ce processus.
Comment contacter le service clientèle d’Adobe ? customer-support
Une liste complète des numéros de téléphone du service clientèle d’Adobe est disponible sur la page d’aide d’Adobe. Vous pouvez également trouver de l’aide en ligne en procédant comme suit :
- Accédez à https://www.adobe.com/ dans votre navigateur web.
- Sur le côté droit de la barre de navigation supérieure, sélectionnez Se connecter.
- Utilisez l’Adobe ID et le mot de passe associés à votre licence Adobe.
- Sélectionnez Aide et assistance dans la barre de navigation supérieure.
Une bannière déroulante s’affiche avec une section Aide et assistance. Sélectionnez Nous contacter pour ouvrir l’assistant virtuel de l’assistance clientèle Adobe ou sélectionnez Assistance aux entreprises pour obtenir une aide destinées aux grandes organisations.
Comment mettre en œuvre une série séquentielle de tâches sans exécuter les tâches suivantes si la tâche précédente ne se termine pas correctement ?
La fonction de bloc anonyme vous permet d’enchaîner une ou plusieurs instructions SQL exécutées de manière séquentielle. Les blocs anonymes permettent également de gérer les exceptions.
Pour en savoir plus, consultez la documentation sur les blocs anonymes.
Comment mettre en œuvre l’attribution personnalisée dans Query Service ?
Il existe deux façons de mettre en œuvre l’attribution personnalisée :
- Utilisez une combinaison de fonctions existantes définies par Adobe pour déterminer si les besoins du cas d’utilisation sont satisfaits.
- Si la suggestion précédente ne répond pas à votre cas d’utilisation, vous devez utiliser une combinaison de fonctions de fenêtre. Les fonctions de fenêtre examinent tous les événements d’une séquence. Elles permettent également de consulter les données historiques et peuvent être utilisées dans n’importe quelle combinaison.
Puis-je modéliser mes requêtes afin de pouvoir les réutiliser facilement ?
Comment récupérer les journaux d’erreur d’une requête ? error-logs
Pour récupérer les journaux d’erreur d’une requête spécifique, vous devez d’abord utiliser l’API Query Service pour récupérer les détails du journal de la requête. La réponse HTTP contient les identifiants de requête requis pour rechercher une erreur de requête.
Utilisez la commande GET pour récupérer plusieurs requêtes. Découvrez comment effectuer un appel à l’API dans la documentation sur les exemples d’appels d’API.
À partir de la réponse, identifiez la requête que vous souhaitez analyser et effectuez une autre requête GET à l’aide de sa valeur id
. Vous trouverez des instructions complètes dans la documentation sur la récupération d’une requête à l’aide de l’ID.
Une réponse réussie renvoie un statut HTTP 200 et contient le tableau errors
. Par souci de concision, la réponse a été raccourcie.
code language-json |
---|
|
La documentation de référence sur l’API Query Service fournit plus d’informations sur tous les points d’entrée disponibles.
Que signifie « Erreur de validation du schéma » ?
Le message « Erreur de validation du schéma » signifie que le système ne peut pas localiser un champ dans le schéma. Nous vous recommandons de lire le document des bonnes pratiques relatives à l’organisation des ressources de données dans Query Service ainsi que la documentation sur la requête Create Table As Select (CTAS).
L’exemple suivant illustre l’utilisation d’une syntaxe CTAS et d’un type de données struct :
code language-sql |
---|
|
Comment traiter rapidement les nouvelles données qui entrent chaque jour dans le système ?
SNAPSHOT
pour lire de manière incrémentielle les données d’une table en fonction d’un identifiant d’instantané. Ceci est idéal pour une utilisation avec le modèle de conception de chargement incrémentiel qui traite uniquement les informations du jeu de données qui ont été créées ou modifiées depuis la dernière exécution du chargement. Cela permet d’augmenter l’efficacité du traitement et peut être utilisé avec le traitement des données en flux continu et par lots.Pourquoi y a-t-il une différence entre les nombres affichés dans l’interface utilisateur du profil et les nombres calculés à partir du jeu de données d’exportation du profil ?
Les nombres affichés dans le tableau de bord du profil sont précis à partir du dernier instantané. Les nombres générés dans le tableau d’exportation du profil dépendent entièrement de la requête d’exportation. L’interrogation du nombre de profils admissibles pour une audience particulière constitue donc une cause courante de cette incohérence.
note note |
---|
NOTE |
La requête inclut des données historiques, tandis que l’interface utilisateur affiche uniquement les données de profil actuelles. |
Pourquoi ma requête a-t-elle renvoyé un sous-ensemble vide et que dois-je faire ?
La cause la plus probable est que la portée de votre requête est trop limitée. Vous devez supprimer systématiquement une section de la clause WHERE
jusqu’à ce que vous commenciez à voir des données.
Vous pouvez également confirmer que votre jeu de données contient des données à l’aide d’une requête courte telle que :
code language-sql |
---|
|
Puis-je échantillonner mes données ?
Quelles fonctions d’assistant sont prises en charge par Query Service ?
Toutes les fonctions Spark SQL natives sont-elles prises en charge, ou les utilisateurs et utilisatrices sont-ils limités aux fonctions Spark SQL wrapper fournies par Adobe ?
Les utilisateurs et utilisatrices peuvent-ils définir leurs propres fonctions définies par l’utilisateur (UDF) pour les utiliser dans d’autres requêtes ?
Que dois-je faire si ma requête planifiée échoue ?
Commencez par consulter les journaux pour connaître les détails de l’erreur. La section Questions fréquentes sur la recherche d’erreurs dans les journaux fournit des informations supplémentaires sur la manière de procéder.
Vous pouvez également consulter la documentation pour obtenir des conseils sur la manière d’effectuer des requêtes planifiées dans l’interface utilisateur et par le biais de l’API.
N’oubliez pas que lorsque vous utilisez le Query Editor, vous ne pouvez ajouter qu’un planning à une requête qui a déjà été créée et enregistrée. Ceci ne s’applique pas à l’API Query Service.
Que signifie l’erreur « Limite de session atteinte » ?
Comment le journal de requête gère-t-il les requêtes relatives à un jeu de données supprimé ?
Comment puis-je obtenir uniquement les métadonnées d’une requête ?
Vous pouvez exécuter une requête qui renvoie zéro ligne pour obtenir uniquement les métadonnées en réponse. Cet exemple de requête renvoie uniquement les métadonnées de la table spécifiée.
code language-sql |
---|
|
Comment puis-je itérer rapidement sur une requête CTAS (Create Table As Select) sans la matérialiser ?
Vous pouvez créer des tables temporaires pour itérer rapidement une requête et l’expérimenter avant de la matérialiser pour l’utiliser. Vous pouvez également utiliser des tables temporaires pour vérifier si une requête est fonctionnelle.
Vous pouvez, par exemple, créer une table temporaire :
code language-sql |
---|
|
Vous pouvez ensuite utiliser la table temporaire comme suit :
code language-sql |
---|
|
Comment modifier le fuseau horaire en heure et date UTC ?
Adobe Experience Platform conserve les données au format d’heure et date UTC (temps universel coordonné). Exemple de format UTC : 2021-12-22T19:52:05Z
.
Query Service prend en charge les fonctions SQL intégrées pour convertir une date et une heure données au format UTC et inversement à partir de ce format. Les deux méthodes to_utc_timestamp()
et from_utc_timestamp()
prennent deux paramètres : la date et l’heure, ainsi que le fuseau horaire.
table 0-row-2 1-row-2 2-row-2 | |
---|---|
Paramètre | Description |
Date et heure | La date et l’heure peuvent être écrites au format UTC ou au format {year-month-day} simple. Si aucune heure n’est fournie, la valeur par défaut est minuit le matin du jour donné. |
Fuseau horaire | Le fuseau horaire est écrit dans le format {continent/city}) . Il doit s’agir de l’un des codes de fuseau horaire reconnus, comme indiqué dans la base de données TZ du domaine public. |
Convertir en date et heure UTC
La méthode to_utc_timestamp()
interprète les paramètres donnés et les convertit à l’heure et à la date de votre fuseau horaire local au format UTC. Par exemple, le fuseau horaire à Séoul, en Corée du Sud, est UTC/GMT +9 heures. En fournissant une date uniquement, la méthode utilise une valeur par défaut de minuit le matin. L’heure, la date et le fuseau horaire sont convertis au format UTC de l’heure de cette région en date et heure UTC de votre région locale.
code language-sql |
---|
|
La requête renvoie une date et une heure à l’heure locale de l’utilisateur ou utilisatrice. Dans ce cas, la veille à 15h00 comme à Séoul, il y a neuf heures d’avance.
code language-none |
---|
|
Autre exemple : si la date et l’heure données ont été 2021-07-14 12:40:00.0
pour le fuseau horaire Asia/Seoul
, la date et l’heure UTC renvoyées seraient 2021-07-14 03:40:00.0
.
La sortie de console fournie dans l’interface utilisateur de Query Service est plus lisible :
code language-none |
---|
|
Convertir à partir de la date et heure UTC
La méthode from_utc_timestamp()
interprète les paramètres donnés à partir de la date et de l’heure de votre fuseau horaire local, et fournit la date et l’heure équivalentes de la région souhaitée au format UTC. Dans l’exemple ci-dessous, l’heure est 14h40 dans le fuseau horaire local de l’utilisateur ou utilisatrice. Le fuseau horaire de Séoul passé en tant que variable est neuf heures en avance sur le fuseau horaire local.
code language-sql |
---|
|
La requête renvoie une date et une heure au format UTC pour le fuseau horaire transmis en tant que paramètre. Le résultat est neuf heures en avance sur le fuseau horaire qui a exécuté la requête.
code language-none |
---|
|
Comment dois-je filtrer mes données de série temporelle ?
accordion | |||||
---|---|---|---|---|---|
Réponse | |||||
Lors de l’interrogation de données de série temporelle, vous devez utiliser le filtre Date et heure chaque fois que cela est possible pour une analyse plus précise.
Vous trouverez ci-dessous un exemple d’utilisation du filtre Date et heure :
|
Comment utiliser correctement l’opérateur CAST
pour convertir mes dates et heures dans les requêtes SQL ?
Lors de l’utilisation de l’opérateur CAST
pour convertir une date et une heure, vous devez inclure la date et l’heure.
Par exemple, l’absence du composant Heure, comme illustré ci-dessous, entraînera une erreur :
code language-sql |
---|
|
L’utilisation correcte de l’opérateur CAST
est illustrée ci-dessous :
code language-sql |
---|
|
Dois-je utiliser des caractères génériques, tels que * pour obtenir toutes les lignes de mes jeux de données ?
Dois-je utiliser NOT IN
dans ma requête SQL ?
L’opérateur NOT IN
est souvent utilisé pour récupérer les lignes qui ne figurent pas dans une autre table ou instruction SQL. Cet opérateur peut ralentir les performances et renvoyer des résultats inattendus si les colonnes comparées acceptent NOT NULL
, ou si vous avez un grand nombre d’enregistrements.
Au lieu d’utiliser NOT IN
, vous pouvez utiliser NOT EXISTS
ou LEFT OUTER JOIN
.
Par exemple, si vous avez les tables suivantes créées :
code language-sql |
---|
|
Si vous utilisez l’opérateur NOT EXISTS
, vous pouvez répliquer à l’aide de l’opérateur NOT IN
en utilisant la requête suivante :
code language-sql |
---|
|
Si vous utilisez l’opérateur LEFT OUTER JOIN
, vous pouvez répliquer à l’aide de l’opérateur NOT IN
en utilisant la requête suivante :
code language-sql |
---|
|
Puis-je créer un jeu de données à l’aide d’une requête CTAS avec un nom de soulignement double comme celui affiché dans l’interface utilisateur ? Par exemple : test_table_001
.
Combien de requêtes simultanées est-il possible d’exécuter à la fois ?
Y a-t-il un tableau de bord d’activité dans lequel vous pouvez voir les activités et le statut des requêtes ?
Existe-t-il un moyen de restaurer les mises à jour ? Par exemple, en cas d’erreur ou si certains calculs doivent être reconfigurés lors de l’écriture de données dans Platform, comment ce scénario doit-il être géré ?
Comment optimiser les requêtes dans Adobe Experience Platform ?
Le système ne possède pas d’index, car il ne s’agit pas d’une base de données, mais d’autres optimisations sont en place, liées à l’entrepôt de données. Les options suivantes sont disponibles pour régler vos requêtes :
- Filtre temporel basé sur les données de série temporelle.
- Optimisation du pushdown pour le type de données struct.
- Optimisation du coût et du pushdown de la mémoire pour les types de données de tableaux et de mappage.
- Traitement incrémentiel à l’aide d’instantanés.
- Format de données persistant.
Les connexions peuvent-elles être limitées à certains aspects de Query Service ou s’agit-il d’une solution « tout ou rien » ?
Puis-je restreindre les données que Query Service peut utiliser ou accède-t-il simplement à l’ensemble du lac de données d’Adobe Experience Platform ?
Quelles autres options existe-t-il pour limiter les données auxquelles Query Service peut accéder ?
Il existe trois approches pour restreindre l’accès. En voici la liste :
- Utilisez les instructions SELECT uniquement et accordez aux jeux de données un accès en lecture seule. Attribuez également l’autorisation de gestion des requêtes.
- Utilisez des instructions SELECT/INSERT/CREATE et accordez aux jeux de données un accès en écriture. Attribuez également l’autorisation de gestion des requêtes.
- Utilisez un compte d’intégration avec les suggestions précédentes et attribuez l’autorisation d’intégration de requête.
Une fois les données renvoyées par Query Service, existe-t-il des vérifications pouvant être exécutées par Platform pour s’assurer qu’elles n’ont renvoyé aucune donnée protégée ?
- Query Service prend en charge le contrôle d’accès basé sur les attributs. Vous pouvez restreindre l’accès aux données au niveau de la colonne, de la feuille et/ou au niveau struct. Consultez la documentation pour en savoir plus sur le contrôle d’accès basé sur les attributs.
Puis-je spécifier un mode SSL pour la connexion à un client tiers ? Par exemple, puis-je utiliser « verify-full » avec Power BI ?
Utilisons-nous TLS 1.2 pour toutes les connexions des clients Power BI à Query Service ?
Une connexion établie sur le port 80 utilise-t-elle toujours https ?
Puis-je contrôler l’accès à des jeux de données et à des colonnes spécifiques pour une connexion particulière ? Comment cela est-il configuré ?
Query Service prend-il en charge la commande « INSERT OVERWRITE INTO » ?
À quelle fréquence les données d’utilisation du tableau de bord d’utilisation des licences sont-elles mises à jour pour les heures de calcul de Data Distiller ?
Puis-je utiliser la commande CREATE VIEW sans accès à Data Distiller ?
CREATE VIEW
sans accès à Data Distiller. Cette commande offre une vue logique des données, mais ne les réécrit pas dans le lac de données.Puis-je utiliser des blocs anonymes dans DbVisualizer ?
Interface utilisateur des requêtes
La "Créer une requête" est bloquée "Initialisation de la connexion…" lors de la tentative de connexion à Query Service. Comment résoudre le problème ?
Échantillon de jeux de données
Puis-je créer des exemples sur un jeu de données système ?
Exportation des données exporting-data
Cette section fournit des informations sur l’exportation des données et des limites.
Existe-t-il un moyen d’extraire des données de Query Service après le traitement des requêtes et d’enregistrer les résultats dans un fichier CSV ? export-csv
Oui. Les données peuvent être extraites de Query Service et il est également possible de stocker les résultats au format CSV via une commande SQL.
Il existe deux manières d’enregistrer les résultats d’une requête quand on utilise un client PSQL. Vous pouvez utiliser la commande COPY TO
ou créez une instruction en respectant le format suivant :
code language-sql |
---|
|
Les instructions sur l’utilisation de la commande COPY TO
se trouvent dans la documentation de référence de syntaxe SQL.
Puis-je extraire le contenu du jeu de données final qui a été ingéré par le biais de requêtes CTAS (en supposant qu’il s’agisse de grandes quantités de données telles que des Terabytes) ?
Pourquoi le connecteur de données Analytics ne renvoie-t-il pas de données ?
Une cause courante de ce problème est l’interrogation de données de série temporelle sans filtre temporel. Par exemple :
code language-sql |
---|
|
Doit être écrit comme suit :
code language-sql |
---|
|
Syntaxe SQL
La FUSION DANS est-elle prise en charge par Data Distiller ou Query Service ?
Requêtes ITAS
Que sont les requêtes ITAS ?
Outils tiers third-party-tools
Cette section contient des informations sur l’utilisation d’outils tiers tels que PSQL et Power BI.
Puis-je connecter Query Service à un outil tiers ?
Existe-t-il un moyen de connecter Query Service une seule fois pour une utilisation continue avec un outil tiers ?
Pourquoi mes informations d’identification non expirantes ne fonctionnent-elles pas ?
technicalAccountID
et credential
extraits du fichier de configuration JSON. La valeur du mot de passe se présente comme suit : {{technicalAccountId}:{credential}}
.Pour plus d’informations sur la connexion à des clients externes à l’aide d’informations d’identification, consultez la documentation.
Quels types d’éditeurs SQL tiers puis-je connecter à Query Service Editor ?
Puis-je connecter l’outil Power BI à Query Service ?
Pourquoi le chargement des tableaux de bord est-il long lorsque le système est connecté à Query Service ?
Lorsque le système est connecté à Query Service, il est connecté à un moteur de traitement interactif ou par lots. Cela peut entraîner des temps de chargement plus longs pour refléter les données traitées.
Si vous souhaitez améliorer les temps de réponse de vos tableaux de bord, vous devez mettre en oeuvre un serveur Business Intelligence (BI) en tant que couche de mise en cache entre Query Service et les outils de BI. La plupart des outils de BI offrent une option de serveur dans leur assortiment.
L’ajout de la couche de serveur de mise en cache a pour but de mettre en cache les données de Query Service et d’utiliser les mêmes données pour les tableaux de bord, à des fins de temps de réponse réduits. Pour ce faire, les résultats des requêtes exécutées sont mis en cache sur le serveur BI quotidiennement. Le serveur de mise en cache fournit ensuite ces résultats à tout(e) utilisateur ou utilisatrice soumettant la même requête afin de réduire la latence. Pour plus d’informations sur cette mise en œuvre, consultez la documentation de l’utilitaire ou de l’outil tiers que vous utilisez.
Est-il possible d’accéder à Query Service à l’aide de l’outil de connexion pgAdmin ?
Erreurs de l’API PostgreSQL postgresql-api-errors
Le tableau suivant fournit les codes d’erreur PSQL et leurs causes possibles.
AuthenticationCleartextPassword
.CREATE TABLE
.dbName
: vérifiez le nom dbName
.Pourquoi ai-je reçu un code d’erreur 58000 lors de l’utilisation de la méthode history_meta() sur ma table ?
La méthode history_meta()
sert à accéder à un instantané d’un jeu de données. Auparavant, si vous deviez exécuter une requête sur un jeu de données vide dans Azure Data Lake Storage (ADLS), vous receviez un code d’erreur 58000 indiquant que le jeu de données n’existe pas. Consultez ci-dessous un exemple de l’ancienne erreur système.
code language-shell |
---|
|
Cette erreur se produisait car aucune valeur n’était renvoyée pour la requête. Ce comportement est désormais corrigé et renvoie le message suivant :
code language-text |
---|
|
Erreurs de l’API REST rest-api-errors
Le tableau suivant fournit des codes d’erreur HTTP et leurs causes possibles.