SHOW DBT PROJECTS

Lista os objetos de projeto dbt para os quais você tem privilégios de acesso.

Você pode usar este comando para listar os objetos no banco de dados e esquema atuais da sessão, em um banco de dados ou esquema especificado ou em toda a sua conta.

A saída inclui os metadados e as propriedades de cada objeto. Os objetos são classificados lexicograficamente por banco de dados, esquema e nome do objeto (consulte Saída neste tópico para obter descrições das colunas de saída). A ordem das linhas nos resultados é importante para filtrar os resultados.

Consulte também:

CREATE DBT PROJECT, ALTER DBT PROJECT, EXECUTE DBT PROJECT, DROP DBT PROJECT, SHOW DBT PROJECTS

Sintaxe

SHOW DBT PROJECTS [ LIKE '<pattern>' ]
           [ IN
                {
                  ACCOUNT                  |

                  DATABASE                 |
                  DATABASE <database_name> |

                  SCHEMA                   |
                  SCHEMA <schema_name>     |
                  <schema_name>
                }
           ]
           [ STARTS WITH '<name_string>' ]
           [ LIMIT <rows> ]
           [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Parâmetros

LIKE 'pattern'

Opcionalmente, filtra a saída do comando pelo nome do objeto. O filtro utiliza correspondência de padrão que não diferencia maiúsculas e minúsculas, com suporte para caracteres curinga SQL (% e _).

Por exemplo, os seguintes padrões retornam os mesmos resultados:

... LIKE '%testing%' ...
... LIKE '%TESTING%' ...

. padrão: sem valor (nenhuma filtragem é aplicada à saída).

[ IN ... ]

Opcionalmente, especifica o escopo do comando. Especifique um dos seguintes:

ACCOUNT

Retorna registros para toda a conta.

DATABASE, . DATABASE db_name

Retorna registros do banco de dados atual em uso ou de um banco de dados especificado (db_name).

Se você especificar DATABASE sem db_name e nenhum banco de dados estiver em uso, a palavra-chave não terá efeito sobre a saída.

Nota

Usar comandos SHOW sem uma cláusula IN em um contexto de banco de dados pode resultar em menos resultados do que o esperado.

Os objetos com o mesmo nome são exibidos apenas uma vez se não for usada a cláusula IN. Por exemplo, se a tabela t1 estiver em schema1 e a tabela t1 estiver em schema2 e ambas estiverem no escopo do contexto do banco de dados especificado (ou seja, o banco de dados selecionado é o pai de schema1 e schema2), então SHOW TABLES exibirá apenas uma das tabelas t1.

SCHEMA, . SCHEMA schema_name

Retorna registros do esquema atual em uso ou de um esquema especificado (schema_name).

SCHEMA é opcional se um banco de dados estiver em uso ou se você especificar o schema_name totalmente qualificado (por exemplo, db.schema).

Se nenhum banco de dados estiver em uso, a especificação SCHEMA não terá efeito sobre a saída.

Se você omitir IN ..., o escopo do comando dependerá se a sessão tem um banco de dados em uso:

  • If a database is currently in use, the command returns the objects you have privileges to view in the database. This has the same effect as specifying IN DATABASE.

  • If no database is currently in use, the command returns the objects you have privileges to view in your account. This has the same effect as specifying IN ACCOUNT.

STARTS WITH 'name_string'

Opcionalmente, filtra a saída do comando com base nos caracteres que aparecem no início do nome do objeto. A cadeia de caracteres deve ser colocada entre aspas simples e faz distinção entre letras maiúsculas e minúsculas.

Por exemplo, as seguintes cadeias de caracteres retornam resultados diferentes:

... STARTS WITH 'B' ...
... STARTS WITH 'b' ...

. Padrão: sem valor (nenhuma filtragem é aplicada à saída)

LIMIT rows

Opcionalmente, limita o número máximo de linhas retornadas. O número real de linhas retornadas pode ser menor que o limite especificado. Por exemplo, o número de objetos existentes é menor que o limite especificado.

Padrão: sem valor (nenhum limite é aplicado à saída).

LIMIT rows [ FROM 'name_string' ]

Opcionalmente, limita o número máximo de linhas retornadas, ao mesmo tempo em que permite a «paginação» dos resultados. O número real de linhas retornadas pode ser menor que o limite especificado. Por exemplo, o número de objetos existentes é menor que o limite especificado.

A subcláusula opcional FROM 'name_string' serve efetivamente como um “cursor” para os resultados. Isso permite obter o número especificado de linhas seguindo a primeira linha cujo nome do objeto corresponde à cadeia de caracteres especificada:

  • A cadeia de caracteres deve ser colocada entre aspas simples e faz distinção entre letras maiúsculas e minúsculas.

  • A cadeia de caracteres não precisa incluir o nome completo do objeto; também é permitido usar nomes parciais.

Padrão: nenhum valor (nenhum limite é aplicado à saída)

Nota

Para comandos SHOW que oferecem suporte às cláusulas FROM 'name_string' e STARTS WITH 'name_string', você pode combinar ambas as cláusulas na mesma instrução. No entanto, ambas as condições devem ser cumpridas ou elas se cancelam mutuamente e nenhum resultado é retornado.

Além disso, os objetos são devolvidos em ordem lexicográfica por nome, portanto FROM 'name_string' só retorna linhas com um valor lexicográfico maior que as linhas retornadas por STARTS WITH 'name_string'.

Por exemplo:

  • ... STARTS WITH 'A' LIMIT ... FROM 'B' não retornaria nenhum resultado.

  • ... STARTS WITH 'B' LIMIT ... FROM 'A' não retornaria nenhum resultado.

  • ... STARTS WITH 'A' LIMIT ... FROM 'AB' retornariam resultados (se alguma linha corresponder às cadeias de caracteres de entrada).

Saída

A saída do comando inclui as seguintes colunas, que descrevem as propriedades e metadados do objeto:

Coluna

Descrição

external_access_integrations

O nome das integrações de acesso externo que o projeto dbt tem permissão para usar para extrair dependências remotas do hub de pacotes dbt ou do Github.

name

O identificador do objeto de projeto dbt.

database_name

O nome do banco de dados no qual o objeto de projeto dbt está definido.

schema_name

O nome do esquema no qual o objeto do projeto dbt é definido.

created_on

Data e hora em que o objeto de projeto dbt foi criado.

updated_on

Data e hora em que o objeto de projeto dbt foi atualizado pela última vez.

owner

O nome da função que possui o objeto de projeto dbt.

comment

O comentário associado ao objeto de projeto dbt.

dbt_snowflake_version

The Snowflake version the dbt project object is on.

default_target

O destino de execução padrão (por exemplo, prod ou dev) usado por comandos dbt executados pelo Snowflake.

As colunas a seguir mostram o valor de um parâmetro obsoleto:

Coluna

Descrição

default_version

The version of the dbt project object:

  • LAST: The most recent version of the dbt project object.

  • FIRST: The oldest version of the dbt project object.

default_version_name

O identificador de versão no formato VERSION$num, em que num é um número inteiro positivo, por exemplo: VERSION$1.

O número da versão começa em 1, quando você cria um objeto de projeto dbt, e é incrementado por um a cada nova versão do objeto de projeto dbt.

O Snowflake incrementa o identificador de versão quando você executa as seguintes tarefas:

  • Reimplanta o projeto dbt de um espaço de trabalho (executa o comando ALTER com a opção ADD VERSION).

  • Atualize o projeto usando o comando ALTER DBT PROJECT.

  • Executar o comando snow dbt deploy da Snow CLI com a opção --force.

O Snowflake redefine o identificador de versão para 1 e remove todos os aliases de versão quando você executa o comando CREATE DBT PROJECT com a opção OR REPLACE.

default_version_alias

O alias de nome de versão personalizado que você criou para uma versão específica do objeto de projeto dbt usando o comando ALTER DBT PROJECT com a opção ADD VERSION. Um alias de nome de versão sempre mapeia para um identificador de versão específico, como VERSION$3.

default_version_location_uri

O URI do local da versão padrão. Este é somente leitura.

default_version_source_location_uri

O URI do local dos arquivos de origem da versão padrão no respectivo objeto Git. Se o objeto de projeto dbt não estiver conectado a um objeto Git, esse valor será nulo.

dbt_snowflake_version

The Snowflake version the dbt project object is on.

Requisitos de controle de acesso

Uma função usada para executar esse comando SQL deve ter pelo menos um dos seguintes privilégios, no mínimo:

Privilégio

Objeto

USAGE

Projeto dbt

MONITOR

Projeto dbt

A operação em um objeto de esquema requer pelo menos um privilégio no banco de dados pai e um privilégio no esquema pai.

Para instruções sobre como criar uma função personalizada com um conjunto específico de privilégios, consulte Criação de funções personalizadas.

Para informações gerais sobre concessões de funções e privilégios para executar ações de SQL em objetos protegíveis, consulte Visão geral do controle de acesso.

Notas de uso

  • O comando não precisa de um warehouse em funcionamento para ser executado.

  • O comando retorna apenas objetos para os quais a função atual do usuário atual recebeu pelo menos um privilégio de acesso.

  • O privilégio de acesso MANAGE GRANTS permite implicitamente que seu titular consulte todos os objetos da conta. Por padrão, somente o administrador de conta (usuários com a função ACCOUNTADMIN) e o administrador de segurança (usuários com a função SECURITYADMIN) têm o privilégio MANAGE GRANTS.

  • Para pós-processar a saída deste comando, você pode usar o operador de canal (->>) ou a função RESULT_SCAN. Ambos os constructos tratam a saída como um conjunto de resultados que você pode consultar.

    Por exemplo, é possível usar o operador de canal ou a função RESULT_SCAN para selecionar colunas específicas da saída do comando SHOW ou filtrar as linhas.

    Quando você fizer referência a colunas de saída, use identificadores entre aspas duplas para os nomes das colunas. Por exemplo, para selecionar a coluna de saída type, especifique SELECT "type".

    Você deve usar identificadores entre aspas duplas porque os nomes das colunas de saída para os comandos SHOW estão em minúsculas. As aspas duplas garantem que os nomes das colunas na lista SELECT ou na cláusula WHERE correspondam aos nomes das colunas na saída do comando SHOW que foi verificada.

  • O comando retorna um máximo de dez mil registros para o tipo de objeto especificado, conforme ditado pelos privilégios de acesso da função usada para executar o comando. Todos os registros acima do limite de dez mil registros não são retornados, mesmo com um filtro aplicado.

    Para visualizar os resultados para os quais existem mais de dez mil registros, consulte a exibição correspondente (se houver) em Snowflake Information Schema.

  • O valor de LIMIT rows não pode exceder 10000. Se LIMIT rows for omitido, o comando resultará em um erro se o conjunto de resultados for maior que dez mil linhas.

    Para visualizar os resultados para os quais existem mais de dez mil registros, inclua LIMIT rows ou consulte a exibição correspondente em Snowflake Information Schema.

Exemplos

The following example lists the dbt project objects that you have privileges to view in the public schema of the my_db database:

SHOW DBT PROJECTS IN DATABASE my_db;
Copy
+-----------------------------+----------------+---------------+-------------+-------------------------------+-------------------------------+--------------+---------+-----------------+----------------------+-----------------------+------------------------------------------------------------+-------------------------------------+-----------------------+----------------+
| external_access_integrations |    name        | database_name | schema_name |          created_on           |          updated_on           |    owner     | comment | default_version | default_version_name | default_version_alias | default_version_location_uri                               | default_version_source_location_uri | dbt_snowflake_version | default_target |
+-----------------------------+----------------+---------------+-------------+-------------------------------+-------------------------------+--------------+---------|-----------------|----------------------|-----------------------+------------------------------------------------------------+-------------------------------------+-----------------------+----------------+
| my_ext_integration_1        | COSMOS         | MY_DB         | PUBLIC      | 2025-04-29 17:21:25.413 -0700 | 2025-04-29 17:21:29.462 -0700 | ACCOUNTADMIN |         | LAST            | VERSION$1            | null                  | snow://dbt/MY_DB.PUBLIC.COSMOS/versions/version$1/         | @s1                                 | 1.9.2b                | null           |
| my_ext_integration_1        | Jaffle_shop    | MY_DB         | PUBLIC      | 2025-03-25 12:36:16.574 -0700 | 2025-03-25 12:36:17.833 -0700 | ACCOUNTADMIN |         | LAST            | VERSION$1            | null                  | snow://dbt/MY_DB.PUBLIC.Jaffle_shop/versions/version$1/    | @s1                                 | 1.9.2b                | prod           |
| my_ext_integration_2        | MY_DBT_PROJECT | MY_DB         | PUBLIC      | 2025-05-02 13:42:36.306 -0700 | 2025-05-02 13:42:38.584 -0700 | ACCOUNTADMIN |         | LAST            | VERSION$1            | null                  | snow://dbt/MY_DB.PUBLIC.MY_DBT_PROJECT/versions/version$1/ | @s1                                 | 1.9.2b                | dev            |
| null                        | MY_SHOP        | MY_DB         | PUBLIC      | 2025-04-29 17:15:27.295 -0700 | 2025-04-29 17:15:28.709 -0700 | ACCOUNTADMIN |         | LAST            | VERSION$1            | null                  | snow://dbt/MY_DB.PUBLIC.MY_SHOP/versions/version$1/        | @s1                                 | 1.9.2b                | null           |
+-----------------------------+----------------+---------------+-------------+-------------------------------+-------------------------------+--------------+---------+-----------------+----------------------+-----------------------+------------------------------------------------------------+-------------------------------------+-----------------------+----------------+