Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Aprenda Desafio: Otimização de Consultas | Otimização de Consultas.Índices
Técnicas Avançadas em SQL

bookDesafio: Otimização de Consultas

Vamos analisar duas tabelas: BankAccounts e uma tabela adicional chamada Transactions.

Tabela BankAccounts

Tabela Transactions

Suponha que desejamos recuperar apenas os números de conta que realizaram pelo menos uma transação.

Nesta tarefa, temos uma consulta que não está otimizada. Sua tarefa é reescrevê-la de forma mais eficiente.

Aqui está uma lista das principais técnicas de reescrita de consultas para melhorar a otimização:

  1. Especificar Colunas Explicitamente: Em vez de usar o caractere curinga (*), mencione explicitamente os nomes das colunas nas consultas para obter melhor desempenho, legibilidade e facilidade de manutenção;

  2. Minimizar Subconsultas: Reduza o uso de subconsultas para otimizar o desempenho da consulta. Considere alternativas como joins ou tabelas derivadas para evitar complexidade e sobrecarga;

  3. Evitar Operadores IN Repetidos: Limite o uso do operador IN nas consultas para evitar impacto no desempenho. Em vez disso, considere utilizar cláusulas JOIN ou EXISTS para planos de execução mais eficientes;

  4. Organizar Joins de Forma Lógica: Inicie os joins SQL com a tabela principal e depois faça join com as tabelas relacionadas para otimizar a organização da consulta e o desempenho do mecanismo de banco de dados;

  5. Utilizar Condições WHERE Restritivas: Melhore o desempenho da consulta incluindo condições restritivas na cláusula WHERE para filtrar linhas e aumentar a velocidade de execução;

  6. Refatorar Código em Stored Procedures ou Funções: Encapsule segmentos de código repetitivos em stored procedures ou funções definidas pelo usuário para reutilização, modularidade e manutenção facilitada. Isso pode reduzir redundância e otimizar consultas SQL.

Tarefa

Swipe to start coding

Reescreva a consulta de forma mais otimizada. Observe que é necessário obter apenas os números das contas que realizaram pelo menos uma transação (transferiram dinheiro para outra conta), ordenados em ordem crescente.

Nota

Utilize o tipo de junção LEFT ou INNER para completar esta tarefa.

Solução

Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

Seção 2. Capítulo 7
single

single

Pergunte à IA

expand

Pergunte à IA

ChatGPT

Pergunte o que quiser ou experimente uma das perguntas sugeridas para iniciar nosso bate-papo

close

Awesome!

Completion rate improved to 4.35

bookDesafio: Otimização de Consultas

Deslize para mostrar o menu

Vamos analisar duas tabelas: BankAccounts e uma tabela adicional chamada Transactions.

Tabela BankAccounts

Tabela Transactions

Suponha que desejamos recuperar apenas os números de conta que realizaram pelo menos uma transação.

Nesta tarefa, temos uma consulta que não está otimizada. Sua tarefa é reescrevê-la de forma mais eficiente.

Aqui está uma lista das principais técnicas de reescrita de consultas para melhorar a otimização:

  1. Especificar Colunas Explicitamente: Em vez de usar o caractere curinga (*), mencione explicitamente os nomes das colunas nas consultas para obter melhor desempenho, legibilidade e facilidade de manutenção;

  2. Minimizar Subconsultas: Reduza o uso de subconsultas para otimizar o desempenho da consulta. Considere alternativas como joins ou tabelas derivadas para evitar complexidade e sobrecarga;

  3. Evitar Operadores IN Repetidos: Limite o uso do operador IN nas consultas para evitar impacto no desempenho. Em vez disso, considere utilizar cláusulas JOIN ou EXISTS para planos de execução mais eficientes;

  4. Organizar Joins de Forma Lógica: Inicie os joins SQL com a tabela principal e depois faça join com as tabelas relacionadas para otimizar a organização da consulta e o desempenho do mecanismo de banco de dados;

  5. Utilizar Condições WHERE Restritivas: Melhore o desempenho da consulta incluindo condições restritivas na cláusula WHERE para filtrar linhas e aumentar a velocidade de execução;

  6. Refatorar Código em Stored Procedures ou Funções: Encapsule segmentos de código repetitivos em stored procedures ou funções definidas pelo usuário para reutilização, modularidade e manutenção facilitada. Isso pode reduzir redundância e otimizar consultas SQL.

Tarefa

Swipe to start coding

Reescreva a consulta de forma mais otimizada. Observe que é necessário obter apenas os números das contas que realizaram pelo menos uma transação (transferiram dinheiro para outra conta), ordenados em ordem crescente.

Nota

Utilize o tipo de junção LEFT ou INNER para completar esta tarefa.

Solução

Switch to desktopMude para o desktop para praticar no mundo realContinue de onde você está usando uma das opções abaixo
Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

close

Awesome!

Completion rate improved to 4.35
Seção 2. Capítulo 7
single

single

some-alt