Cette page définit les principaux termes et concepts que vous rencontrerez probablement souvent pendant le développement de LookML:
- Projets LookML
- Principales structures LookML (modèles, vues et explorations, par exemple)
- Tableaux dérivés
- Connexions à la base de données
- Sensibilité à la casse
Cette page ne présente pas d'apparences ni de tableaux de bord définis par l'utilisateur, car les utilisateurs les créent sans LookML. Cependant, leurs requêtes reposent sur les éléments LookML sous-jacents abordées sur cette page.
Consultez le glossaire Looker pour obtenir la liste complète des termes et des définitions utilisés dans Looker. Pour une présentation complète des paramètres LookML que vous pouvez utiliser dans un projet LookML, consultez la documentation de référence sur LookML.
projet LookML
Dans Looker, un projet est un ensemble de fichiers décrivant les objets, les connexions à la base de données et les éléments d'interface utilisateur qui permettent d'exécuter des requêtes SQL. Au niveau de base, ces fichiers décrivent les relations entre vos tables de base de données et la façon dont Looker les interprète. Ils peuvent également inclure des paramètres LookML qui définissent ou modifient les options présentées dans l'interface utilisateur de Looker. Chaque projet LookML se trouve dans son propre dépôt Git pour le contrôle des versions.
Une fois que vous avez connecté Looker à votre base de données, vous pouvez spécifier la connexion de la base de données à utiliser pour votre projet Looker.
Vous pouvez accéder à vos projets depuis la section Développer de la navigation Looker.
Pour en savoir plus sur la création d'un projet, consultez Créer un projet LookML. Pour savoir comment accéder aux projets LookML existants et y apporter des modifications, consultez Accéder aux informations d'un projet et les modifier.
Composantes d'un projet
Comme le montre le schéma ci-dessus, voici quelques-uns des types de fichiers les plus courants dans un projet LookML:
- Un modèle contient des informations sur les tables à utiliser et sur la manière dont elles doivent être jointes. Ici, vous allez généralement définir le modèle, ses explorations et ses jointures.
- Une vue contient des informations sur la façon d'accéder aux informations de chaque table (ou sur plusieurs tables associées) ou de les calculer. Ici, vous définirez généralement la vue, ses dimensions et mesures, ainsi que ses ensembles de champs.
- Une exploration est souvent définie dans un fichier de modèle, mais vous avez parfois besoin d'un fichier d'exploration distinct pour une table dérivée, ou pour étendre ou affiner une exploration entre plusieurs modèles.
- Un fichier manifeste peut contenir des instructions sur l'utilisation de fichiers importés à partir d'un autre projet ou pour les paramètres de localisation de votre projet.
Outre les types de fichiers ci-dessus, un projet peut avoir d'autres types de fichiers liés aux tableaux de bord intégrés, à la documentation, à la localisation, etc. Consultez la page de fichiers de projet LookML pour en savoir plus sur ces types de fichiers, ainsi que sur les autres types de fichiers disponibles dans votre projet LookML.
Ces fichiers constituent un seul projet. Si vous utilisez Git pour le contrôle des versions, chaque projet est généralement sauvegardé par son propre dépôt Git.
Origine des projets et fichiers LookML
La méthode la plus courante pour créer des fichiers LookML consiste à générer un projet LookML à partir de votre base de données. Vous pouvez également créer un projet vide et créer manuellement ses fichiers LookML, ou créer un projet en clonant un dépôt Git existant.
Lorsque vous créez un nouveau projet depuis votre base de données, Looker crée un jeu de fichiers de référence que vous pouvez utiliser comme modèle pour composer le projet :
- Plusieurs fichiers view, un fichier pour chaque table de la base de données.
- Un fichier model. Le fichier de modèle déclare une exploration pour chaque vue. Chaque déclaration d'exploration inclut la logique
join
pour joindre n'importe quelle vue qui, selon Looker, est liée à l'exploration.
À ce stade, vous pouvez personnaliser le projet en retirant les vues et explorations inutiles et en ajoutant des dimensions et mesures personnalisées.
Principales structures LookML
Comme illustré dans les parties d'un schéma de projet, un projet contient généralement un ou plusieurs fichiers de modèle, qui contiennent des paramètres définissant un modèle ainsi que ses explorations et jointures. En outre, les projets contiennent généralement un ou plusieurs fichiers de vues, chacun contenant des paramètres qui définissent cette vue et ses champs (y compris les dimensions et les mesures) et les ensembles de champs. Le projet peut également contenir un fichier manifeste de projet, ce qui vous permet de configurer les paramètres au niveau du projet. Cette section décrit ces principales structures.
Modèle
Un modèle est un portail personnalisé à l'intérieur de la base de données, conçu pour permettre une exploration intuitive des données par des utilisateurs métier spécifiques. Une même connexion de base de données d'un projet LookML peut comporter plusieurs modèles, chacun d'eux pouvant présenter des données différentes d'un utilisateur à l'autre. Par exemple, les commerciaux n'ont pas besoin des mêmes données que les dirigeants de l'entreprise, et vous devrez probablement développer deux modèles pour présenter des vues de la base de données adaptées à chaque utilisateur.
Un modèle spécifie une connexion à une seule base de données. Un développeur définit également les explorations d'un modèle dans son fichier. Par défaut, les explorations sont organisées sous le nom du modèle dans lequel elles sont définies. Les utilisateurs voient les modèles répertoriés dans le menu Explorer.
Consultez la page de documentation Types de fichiers d'un projet LookML pour en savoir plus sur les fichiers de modèle, y compris la structure et la syntaxe générale des fichiers de modèle.
Pour en savoir plus sur les paramètres LookML pouvant être utilisés dans un fichier de modèle, consultez la page de documentation Paramètres du modèle.
Afficher
Une déclaration de vue définit une liste de champs (dimensions ou mesures), ainsi que leur association à une table sous-jacente ou à une table dérivée. Dans LookML, une vue fait généralement référence à une table de base de données sous-jacente, mais peut également représenter une table dérivée.
Une vue peut être jointe à d'autres vues. La relation entre les vues est généralement définie dans une déclaration Explore dans un fichier de modèle.
Par défaut, les noms des vues apparaissent au début de la dimension et des noms de mesure dans le tableau de données Explorer. Cette convention de dénomination permet d'identifier clairement la vue à laquelle le champ appartient. Dans l'exemple suivant, les noms de vue Commandes et Utilisateurs sont répertoriés avant les noms des champs de la table de données:
Pour en savoir plus sur les fichiers d'affichage, y compris la structure et la syntaxe générale des fichiers d'affichage, consultez la documentation Types de fichiers dans un projet LookML.
Pour en savoir plus sur les paramètres LookML pouvant être utilisés dans un fichier d'affichage, consultez la page de documentation Afficher les paramètres.
Explorer
Une exploration est une vue que les utilisateurs peuvent interroger. Vous pouvez considérer Explorer comme le point de départ d'une requête ou, en termes SQL, comme l'élément FROM
d'une instruction SQL. Toutes les vues ne sont pas des explorations, car elles ne décrivent pas toutes une entité présentant un intérêt. Par exemple, la vue États correspondant à un tableau de conversion pour les noms d'État ne garantit pas une exploration, car les utilisateurs professionnels n'ont jamais besoin de l'interroger directement. D'un autre côté, les utilisateurs professionnels recherchent probablement un moyen d'interroger une vue Orders. Il peut donc être judicieux de définir la propriété Explorer pour Orders.
Dans Looker, vos utilisateurs peuvent voir les explorations dans le menu Explorer. Les explorations sont listées sous les noms des modèles auxquels elles appartiennent.
Par convention, les explorations sont déclarées dans le fichier de modèle avec le paramètre explore
. Dans cet exemple de fichier de modèle, l'option orders
Explorer pour une base de données d'e-commerce est définie dans le fichier de modèle. Les vues orders
et customers
référencées dans la déclaration explore
sont définies ailleurs dans leurs fichiers de vue respectifs.
connection: order_database
include: "filename_pattern"
explore: orders {
join: customers {
sql_on: ${orders.customer_id} = ${customers.id} ;;
}
}
Dans l'exemple ci-dessus, le paramètre connection
permet de spécifier la connexion à la base de données du modèle, et le paramètre include
sert à spécifier les fichiers que le modèle doit référencer.
Dans l'exemple ci-dessus, la déclaration explore
spécifie également les relations de jointure entre les vues. Pour en savoir plus sur les déclarations join
, consultez la section sur les jointures sur cette page. Consultez la page de documentation Paramètres de jointure pour en savoir plus sur les paramètres LookML pouvant être utilisés avec le paramètre join
.
Champs de dimension et de mesure
Les vues contiennent des champs, principalement des dimensions et des mesures, qui sont les éléments constitutifs des requêtes Looker.
Dans Looker, une dimension est un champ pouvant faire partie d'un groupe et utilisable pour filtrer les résultats d'une requête. Il peut s'agir :
- d'un attribut, directement associé à une colonne d'une table sous-jacente ;
- d'une valeur factuelle ou numérique ;
- d'une valeur dérivée, calculée à partir des valeurs d'autres champs sur une ligne unique.
Dans Looker, les dimensions apparaissent toujours dans la clause GROUP BY
du langage SQL généré par Looker.
Par exemple, les dimensions d'une vue Produits peuvent inclure le nom, le modèle, la couleur, le prix, la date de création et la date de fin de vie du produit.
Une mesure est un champ qui utilise une fonction d'agrégation SQL, comme COUNT
, SUM
, AVG
, MIN
ou MAX
. Un champ calculé à partir d'autres valeurs de mesure est également une mesure. Les mesures permettent de filtrer des valeurs groupées. Par exemple, pour une vue Ventes, les mesures peuvent inclure le nombre total d'articles vendus (nombre), le prix soldé total (somme) et le prix soldé moyen (moyenne).
Le comportement et les valeurs attendues pour un champ dépendent du type déclaré, tel que string
, number
ou time
. Pour les mesures, les types incluent des fonctions d'agrégation, telles que sum
et percent_of_previous
. Pour en savoir plus, consultez Types de dimensions et Types de mesures.
Dans Looker, les champs sont répertoriés sur la page Explorer dans le sélecteur de champs à gauche de la page. Vous pouvez développer une vue dans l'outil de sélection de champs pour afficher la liste des champs disponibles pour les requêtes à partir de cette vue.
Par convention, les champs sont déclarés dans la vue dont ils font partie, enregistrée dans un fichier de vue. L'exemple suivant illustre plusieurs déclarations de dimension et de mesure. Notez l'utilisation de l'opérateur de substitution ($
) pour référencer des champs sans utiliser de nom de colonne SQL à champ d'application complet.
Voici quelques exemples de déclarations de dimensions et de mesures :
view: orders {
dimension: id {
primary_key: yes
type: number
sql: ${TABLE}.id ;;
}
dimension: customer_id {
sql: ${TABLE}.customer_id ;;
}
dimension: amount {
type: number
value_format: "0.00"
sql: ${TABLE}.amount ;;
}
dimension_group: created {
type: time
timeframes: [date, week]
sql: ${TABLE}.created_at ;;
}
measure: count {
type: count # creates sql COUNT(orders.id)
sql: ${id} ;;
}
measure: total_amount {
type: sum # creates sql SUM(orders.amount)
sql: ${amount} ;;
}
}
Vous pouvez également définir un dimension_group
, qui crée plusieurs dimensions en même temps, et des champs filter
qui présentent divers cas d'utilisation avancés, comme des filtres modélisés.
Consultez la page de documentation Paramètres des champs pour en savoir plus sur la déclaration des champs et sur les différents paramètres applicables.
Jointures
Dans une déclaration explore
, chaque déclaration join
spécifie une vue pouvant être jointe dans Explorer. Lorsqu'un utilisateur crée une requête incluant des champs de plusieurs vues, Looker génère automatiquement une logique de jointure SQL pour présenter correctement la totalité de ces champs.
Voici un exemple de jointure dans une déclaration explore
:
# file: ecommercestore.model.lookml
connection: order_database
include: "filename_pattern" # include all the views
explore: orders {
join: customers {
sql_on: ${orders.customer_id} = ${customers.id} ;;
}
}
Pour en savoir plus, consultez la page de documentation Utiliser des jointures dans LookML.
Fichiers manifestes d'un projet
Votre projet peut contenir un fichier manifeste de projet, utilisé pour les paramètres au niveau du projet, tels que ceux permettant de spécifier d'autres projets à importer dans le projet actuel, de définir des constantes LookML, de spécifier des paramètres de localisation de modèles et d'ajouter des extensions et des visualisations personnalisées à votre projet.
Chaque projet peut contenir un seul fichier manifeste. Le fichier doit être nommé manifest.lkml
et se trouver au niveau racine de votre dépôt Git. Lorsque vous utilisez des dossiers dans l'IDE, assurez-vous que le fichier manifest.lkml
est conservé au niveau racine de la structure de répertoires de votre projet.
Pour importer des fichiers LookML d'un autre projet, utilisez le fichier manifeste de celui-ci pour nommer votre projet actuel et indiquer l'emplacement des projets externes, qui peuvent être stockés en local ou à distance. Exemple :
# This project
project_name: "my_project"
# The project to import
local_dependency: {
project: "my_other_project"
}
remote_dependency: ga_360_block {
url: "https://github.com/llooker/google_ga360"
ref: "4be130a28f3776c2bf67a9acc637e65c11231bcc"
}
Après avoir défini les projets externes dans le fichier manifeste du projet, vous pouvez utiliser le paramètre include
dans votre fichier de modèle pour ajouter des fichiers de ce projet externe à votre projet actuel. Exemple :
include: "//my_other_project/imported_view.view"
include: "//ga_360_block/*.view"
Pour en savoir plus, consultez la page de documentation Importer des fichiers à partir d'autres projets.
Pour ajouter des éléments de localisation à votre modèle, utilisez le fichier manifeste du projet pour définir des paramètres de localisation par défaut. Exemple :
localization_settings: {
default_locale: en
localization_level: permissive
}
La définition de paramètres de localisation par défaut est l'une des étapes de la localisation d'un modèle. Pour en savoir plus, consultez la page Localiser votre modèle LookML.
Jeux
Dans Looker, un ensemble est une liste qui définit un groupe de champs utilisés ensemble. En règle générale, les ensembles permettent de spécifier les champs à afficher après qu'un utilisateur a accédé aux détails. Dans ce cas, les jeux sont spécifiés par champ, de sorte que vous maîtrisez totalement les données qui s'affichent lorsqu'un utilisateur clique sur une valeur dans une table ou un tableau de bord. Les jeux peuvent également faire office de fonction de sécurité, pour définir des groupes de champs visibles par certains utilisateurs.
L'exemple suivant illustre une déclaration définie dans une vue order_items
, définissant des champs qui répertorient des détails pertinents sur un article acheté. Notez que les jeux font référence à des champs d'autres vues en définissant une portée.
set: order_items_stats_set {
fields: [
id, # scope defaults to order_items view
orders.created_date, # scope is "orders" view
orders.id,
users.name,
users.history, # show all products this user has purchased
products.item_name,
products.brand,
products.category,
total_sale_price
]
}
Consultez la page de documentation sur le paramètre set
pour obtenir des informations complètes sur l'utilisation des ensembles.
Drill down
Dans Looker, vous pouvez détailler n'importe quel champ configuré à cet effet lors de l'écriture du code LookML. Cette fonction est à la fois compatible avec les tables de résultats de requête et les tableaux de bord. La fonction de détail lance une nouvelle requête, limitée par la valeur sur laquelle l'utilisateur a cliqué.
Le comportement de cette fonction est différent pour les dimensions et les mesures :
- Lorsque l'utilisateur détaille une dimension, le filtre de la nouvelle requête porte sur la valeur détaillée. Par exemple, si vous cliquez sur une date donnée dans une requête de commandes client par date, la nouvelle requête affiche uniquement les commandes passées à cette date.
- Lorsque l'utilisateur détaille une mesure, la nouvelle requête présente le jeu de données ayant contribué à la mesure. Par exemple, lorsqu'il détaille un nombre, la nouvelle requête présente les lignes utilisées pour calculer ce nombre. Lorsque vous affichez le détail des mesures maximale, minimale et moyenne, l'affichage détaillé indique toutes les lignes qui ont contribué à cette mesure. Cela signifie que l'affichage détaillé d'une mesure maximale, par exemple, affiche toutes les lignes utilisées pour calculer la valeur maximale, et non une seule ligne pour la valeur maximale.
Les champs à afficher pour la nouvelle requête d'analyse peuvent être définis par un ensemble, ou par le paramètre drill_fields
(pour les champs) ou le paramètre drill_fields
(pour les vues).
Tables dérivées
Une table dérivée est une requête dont les résultats sont utilisés comme s'il s'agissait d'une table réelle de la base de données. Les tables dérivées sont créées à l'aide du paramètre derived_table
dans une déclaration view
. Looker accède aux tables dérivées comme s'il s'agissait de tables physiques avec leurs propres colonnes. Une table dérivée est exposée en tant que vue à l'aide du paramètre derived_table
, et définit les dimensions et les mesures de la même manière que les vues conventionnelles. Comme n'importe quelle autre vue, celle d'une table dérivée peut faire l'objet de requêtes et être jointe à d'autres vues.
Les tables dérivées peuvent également être définies comme des tables dérivées persistantes (PDT), qui sont des tables dérivées écrites dans un schéma de travail sur votre base de données et générées automatiquement sur la planification que vous spécifiez à l'aide d'une stratégie de persistance.
Pour en savoir plus, consultez la page de documentation Tableaux dérivés dans Looker.
Connexion à la base de données
La connexion de base de données que Looker utilisera pour exécuter les requêtes constitue un autre aspect important des projets LookML. Un administrateur Looker utilise la page Connexions pour configurer les connexions à la base de données. Les développeurs LookML utilisent le paramètre connection
dans un fichier de modèle pour spécifier la connexion à utiliser pour le modèle. Si vous générez un projet LookML à partir de votre base de données, Looker remplira automatiquement le paramètre connection
dans le fichier de modèle.
Sensibilité à la casse
LookML est sensible à la casse, vérifiez donc la casse lorsque vous mentionnez des éléments LookML. Looker vous avertit si vous avez fait référence à un élément qui n'existe pas.
Par exemple, supposons que vous ayez une exploration appelée e_flights_pdt
, et qu'un développeur LookML utilise une casse incorrecte (e_FLIGHTS_pdt
) pour référencer cette exploration. Dans cet exemple, l'IDE Looker affiche un avertissement indiquant que l'exploration e_FLIGHTS_pdt
n'existe pas. En outre, l'IDE suggère le nom d'une exploration existante, qui est e_flights_pdt
:
Toutefois, si votre projet contenait à la fois e_FLIGHTS_pdt
et e_flights_pdt
, l'IDE Looker ne pourrait pas vous corriger. Vous devez donc vous assurer de la version souhaitée. En règle générale, il est recommandé de rester en minuscules lorsque vous nommez des objets LookML.
Les noms des dossiers IDE sont également sensibles à la casse. Vous devez vérifier la casse du nom des fichiers dès que vous spécifiez des chemins de fichier. Par exemple, si vous avez un dossier nommé Views
, vous devez utiliser la même casse dans le paramètre include
. Là encore, l'IDE Looker indique une erreur si la casse ne correspond pas à un dossier existant dans votre projet: