Essas práticas recomendadas refletem as recomendações compartilhadas por uma equipe multidisciplinar de profissionais experientes. Esses insights vêm de anos de experiência trabalhando com clientes do Looker, desde a implementação até o sucesso a longo prazo. As práticas foram criadas para funcionar na maioria dos usuários e situações. No entanto, como sempre, use seu melhor julgamento ao implementar qualquer uma das sugestões desta página.
Esta página oferece recomendações para escrever LookML sustentável e de fácil manutenção. Essas recomendações são descritas em mais detalhes nas seções a seguir:
- Usar operadores de substituição
- Definir conjuntos de campos
- Evitar repetir o código
- Consolidar itens como camadas de mapa e formatos de valor
- Criar diretrizes de desenvolvimento
Usar operadores de substituição
Os operadores de substituição precisam ser usados em todos os arquivos do LookML. Um modelo do LookML precisa ter apenas um ponto de referência para qualquer objeto no modelo de dados físico. Todas as definições subsequentes que precisam fazer referência a esse objeto precisam apontar para o objeto LookML já definido.
Use a sintaxe ${TABLE}.field_name
ao fazer referência à tabela de banco de dados subjacente para todas as dimensões de base que extraem dados diretamente das colunas de banco de dados subjacentes. Se um esquema ou nome de tabela for alterado, o desenvolvedor poderá atualizar o esquema ou o nome da tabela em um local (no parâmetro sql_table_name
) e fazer com que a mudança se propague pelo restante do código.
Use a sintaxe ${field_name}
ao fazer referência a dimensões ou medidas que já foram definidas no LookML. Se o nome de uma coluna mudar, essa mudança só vai precisar ser atualizada no parâmetro sql
da dimensão ou das métricas de base. Essa mudança será propagada automaticamente para todos os outros campos que fazem referência à coluna. Por exemplo, se o nome de uma coluna no seu banco de dados mudar de usersid
para users_id
, você vai precisar mudar a referência no Looker. O uso de ${field_name}
significa que você só precisa atualizar uma linha.
Quando várias dimensões e medidas fazem referência a um campo do LookML com ${TABLE}.field_name
, muitas mudanças são necessárias. Por exemplo, considere as medidas this_week_count
e this_month_count
no exemplo de código do LookML a seguir:
dimension: usersid { type: number sql: ${TABLE}.usersid ;; # Change here } measure: this_week_count { type: count_distinct sql: ${TABLE}.usersid ;; # Change here filters: [created_date: "7 days"] } measure: this_month_count { type: count_distinct sql: ${TABLE}.usersid ;; # Change here filters: [created_date: "1 month"] }
Como this_week_count
e this_month_count
usam a sintaxe ${TABLE}.usersid
no parâmetro sql
, será necessário atualizar o parâmetro sql
nos três campos.
Com a referência ${field_name}
, apenas uma mudança é necessária:
dimension: usersid { type: number sql: ${TABLE}.usersid ;; # Change here } measure: this_week_count { type: count_distinct sql: ${usersid} ;; #Using ${field_name} to reference the LookML field `usersid` filters: [created_date: "7 days"] } measure: this_month_count { type: count_distinct sql: ${usersid} ;; #Using ${field_name} to reference the LookML field `usersid` filters: [created_date: "1 month"] }
Para mais usos de operadores de substituição, consulte a página de documentação Incorporação de SQL e referência a objetos do LookML.
Definir conjuntos de campos
Use conjuntos para manter listas de campos reutilizáveis no modelo. Todas as listas de campos repetidos, com o parâmetro fields
ou em campos de detalhamento, precisam ser incorporadas a conjuntos para criar um único lugar no modelo em que a lista de campos possa ser atualizada ou as referências de campo alteradas. Saiba mais sobre os conjuntos na página de documentação do parâmetro set
.
Evitar código repetitivo
Pense nos objetos do LookML como blocos de construção e use o parâmetro extends
para combinar objetos de maneiras diferentes sem repetir o código. Confira informações detalhadas e exemplos de como reutilizar código na página de documentação Reutilizar código com extends. Confira outros exemplos nas páginas de documentação dos parâmetros extends
(para visualizações) e extends
(para Análises) e na postagem da Comunidade Como usar extensões para definir agrupamentos.
Mantenha a consistência entre as análises detalhadas não repetindo o código em vários lugares. Para mais ideias sobre como fazer isso, consulte a postagem da Comunidade do Looker sobre como evitar inconsistências nas Análises detalhadas.
Consolidar itens como camadas de mapa e formatos de valor
Defina camadas de mapa personalizadas no centro de um arquivo LookML chamado map_layers.lkml
. Para criar esse arquivo, siga a documentação do Looker sobre arquivos de projeto. Esse arquivo pode ser incluído conforme necessário em todos os modelos. Como alternativa, adicione arquivos JSON diretamente ao repositório arrastando e soltando arquivos de dados no seu projeto do LookML e fazendo referência a eles no modelo.
Por exemplo, suponha que você tenha um arquivo de camadas de mapa, map_layers.base.lkml
, contendo o seguinte código do LookML:
map_layer: example_africa { file: "africa_file_name.json" property_key: "geounit" } map_layer: example_asia { file: "asia_file_name.json" property_key: "geounit" } map_layer: example_europe { file: "europe_file_name.json" property_key: "geounit" }
É possível incluir o arquivo de camadas do mapa map_layers.base.lkml
em qualquer modelo do projeto adicionando o código do LookML include: "map_layers.base.lkml"
ao arquivo de modelo desejado.
Defina qualquer formato de valor personalizado de forma centralizada no modelo. Use o parâmetro named_value_format
para definir formatos personalizados no modelo e, em seguida, faça referência a eles usando o parâmetro value_format_name
em dimensões e medidas.
Criar diretrizes de desenvolvimento
Defina diretrizes de desenvolvimento para facilitar o desenvolvimento e o escalonamento de um modelo do LookML. Consulte a postagem da Comunidade do Looker sobre exemplos de diretrizes de desenvolvimento do LookML para conferir um exemplo de lista de diretrizes de desenvolvimento. As diretrizes comuns incluem requisitos para:
- Organizar os arquivos LookML de forma clara para que sejam consistentes e fáceis de navegar
- Usar comentários nas visualizações e nos modelos para adicionar contexto ao LookML escrito
- Criar documentação no Looker usando arquivos Markdown