Diferença entre a cláusula where e having no SQL

Índice:

Diferença entre a cláusula where e having no SQL
Diferença entre a cláusula where e having no SQL

Vídeo: Diferença entre a cláusula where e having no SQL

Vídeo: Diferença entre a cláusula where e having no SQL
Vídeo: SQL - Diferença entre WHERE e HAVING 2024, Julho
Anonim

Key Difference – onde vs tendo cláusula no SQL

Os dados são importantes para todas as organizações. Portanto, é necessário armazenar os dados de forma organizada para recuperá-los. Os dados são armazenados em tabelas. Um banco de dados consiste em uma coleção de tabelas. Um tipo de banco de dados comum são os bancos de dados relacionais. Em um banco de dados relacional, as tabelas estão relacionadas entre si. Por exemplo, a tabela cliente está conectada à tabela de pedidos. Um Sistema de Gerenciamento de Banco de Dados Relacional (RDBMS) é um sistema de gerenciamento de banco de dados baseado no modelo relacional. Ele é usado para gerenciar Bancos de Dados Relacionais. Alguns exemplos de RDBMS são MySQL, MSSQL e Oracle. A Structured Query Language (SQL) é a linguagem usada para manipular e recuperar dados em um banco de dados relacional. Existem várias cláusulas no SQL para executar diferentes tarefas. Dois deles são onde e tendo. Este artigo discute a diferença entre onde e havendo cláusula no SQL. A principal diferença entre a cláusula where e having no SQL é que a cláusula where é usada para filtrar registros antes que um agrupamento ou uma agregação ocorra, enquanto a cláusula have é usada para filtrar registros após um agrupamento ou uma agregação ocorrer.

Qual é a cláusula where no SQL?

Ajuda a recuperar, atualizar ou excluir um determinado conjunto de dados da tabela de acordo com a condição dada. O programador pode usar a cláusula where para restringir e buscar apenas os dados necessários. A consulta é executada apenas nos registros em que a condição especificada pela cláusula where é verdadeira. Pode ser usado com select, update e delete.

Consulte a tabela de alunos abaixo,

Diferença entre a cláusula where e having em SQL_Figura 02
Diferença entre a cláusula where e having em SQL_Figura 02
Diferença entre a cláusula where e having em SQL_Figura 02
Diferença entre a cláusula where e having em SQL_Figura 02

Para selecionar o nome e a idade do aluno cujo student_id é igual a 3, pode-se usar a seguinte consulta SQL.

selecione nome, idade do aluno onde student_id=3;

Também é possível usar operadores como diferente de (!=), maior que (>), menor que (=), menor ou igual a (<=). Para selecionar o Student_id e o nome cuja idade não é igual a 15 anos, a seguinte consulta SQL pode ser usada.

select student_id, nome do aluno onde idade!=15;

Para alterar a idade do aluno de 2 para 13 anos, pode-se usar a seguinte consulta.

atualizar a idade definida do aluno=13 onde id=3;

Para excluir o registro cujo student_id é 4, pode-se usar a seguinte consulta.

delete from student where student_id=4;

Os operadores e, ou podem ser usados para combinar várias condições.

selecione o nome do aluno onde id_aluno=1 e idade=15; consulta irá recuperar o nome Ann.

Estes são alguns exemplos de cláusula where no SQL. Se houver uma cláusula Group By, a cláusula where aparecerá antes dela.

O que é ter cláusula no SQL?

Existem funções fornecidas pela linguagem SQL para realizar cálculos facilmente. São conhecidas como funções de agregação. O min() é usado para encontrar o menor valor da coluna selecionada. O max() é usado para encontrar o valor máximo da coluna selecionada. O avg() é usado para encontrar a média na coluna e sum() é usado para encontrar o total da coluna. Esses são alguns exemplos de funções de agregação. Consulte a tabela de pedidos abaixo,

Diferença entre a cláusula where e having em SQL_Figura 03
Diferença entre a cláusula where e having em SQL_Figura 03
Diferença entre a cláusula where e having em SQL_Figura 03
Diferença entre a cláusula where e having em SQL_Figura 03

O programador pode escrever a consulta SQL da seguinte forma para recuperar os clientes cujo saldo é superior a 2000.

selecionedo grupo de pedidos por cliente com soma(saldo) > 2000.

Isto imprimirá os registros dos clientes cuja soma do saldo é maior que 2000. Imprime os registros dos clientes Ann e Alex.

A cláusula having é usada para recuperar os valores dos grupos que satisfazem certas condições. Portanto, o grupo que se enquadra na condição dada aparecerá como resultado disso. A cláusula having aparece após a cláusula group-by. Se a cláusula group-by não estiver presente, a cláusula having funcionará de forma semelhante à cláusula where.

Quais são as semelhanças entre where e havendo cláusula no SQL?

  • Ambas são cláusulas em Linguagem de Consulta Estruturada.
  • Ambos podem ser usados para filtrar a recuperação de um conjunto de dados.

Qual é a diferença entre a cláusula where e having no SQL?

where vs tendo cláusula no SQL

O where é uma cláusula SQL que é usada para especificar uma condição ao buscar os dados de uma única tabela ou juntando-se a várias tabelas. The having é uma cláusula SQL que especifica que uma instrução SQL select deve retornar apenas linhas onde os valores agregados atendem às condições especificadas.
Objetivo
A cláusula where é usada para filtrar linhas. A cláusula having é usada para filtrar grupos.
Agregação
A cláusula where não pode ser usada com funções de agregação, a menos que esteja em uma subconsulta contida em uma cláusula Tendo. As funções de agregação podem ser usadas com a cláusula having.
Método de filtragem
A cláusula where se comporta como um pré-filtro. A cláusula having se comporta como um pós-filtro.
Agrupar por Ordem de Cláusula
A cláusula where é usada antes da cláusula Group By. A cláusula having é usada após a cláusula Group By.
Usado com
A cláusula where pode ser usada com select, update e delete. A cláusula having é usada apenas com select.

Resumo – cláusula where vs havendo no SQL

A Linguagem de Consulta Estruturada (SQL) é a linguagem usada em bancos de dados relacionais. O where estão tendo são duas cláusulas no SQL. Este artigo discutiu a diferença entre onde e havendo cláusula. A diferença entre where e havendo cláusula no SQL é que where é usado para filtrar registros antes que um agrupamento ou uma agregação ocorra enquanto have é usado para filtrar registros após um agrupamento ou uma agregação ocorrer.

Recomendado: