Minicursos - MySQL

Where com outros operadores


No tópico passado vimos como podem ser usados os operadores AND, OR e NOT. Agora vamos falar de outros três, também muito importantes, que são o BETWEEN, o IS e o IN.

Fazendo um resumo rápido deles, seus papéis são:

- BETWEEN – Especificar um intervalo a ser procurado

- IS – Tratar campos cujos dados são nulos

- IN – Verifica se uma condição ou um valor fazem parte de determinado grupo de valores especificados.

Vamos começar demonstrando o operador BETWEEN, mas antes, só para relembrarmos a estrutura e o conteúdo da nossa tabela de clientes, vamos fazer um select em alguns campos:

SELECT nome AS Nome, email AS Email, idade AS Idade FROM cliente;

Where com outros operadores MySQL

Muito bem. Agora vamos utilizar o operador BETWEEN para especificar que queremos resultados apenas com idades entre 30 a 45 anos.

SELECT nome AS Nome, email AS Email, idade AS Idade FROM cliente WHERE idade BETWEEN 30 AND 45;

Where com outros operadores MySQL

Vejam que o SGBD só nos retornou os dados de clientes cujas idades se encontravam no intervalo que especificamos.

Antes de falar sobre o operador IS é preciso fazer alguns esclarecimentos. Devemos entender o conceito de NULL.

O que é valor NULL?

Quando um SGBD não possui valor algum armazenado em algum campo, ele insere um valor definido como NULL, ou seja, é a ausência total de valor.

O MySQL especifica isso claramente em suas consultas. Vou fazer uma inserção em nossa tabela de clientes e, propositalmente não vou inserir dados em alguns campos, como "endereço" e "idade".

INSERT INTO (telefone, nome, email, cpf) VALUES ("1234-1234", "Rodrigo", "rodrigo@emailinexistente.com", "389476625-11");

Agora vou dar um SELECT apenas nesse cliente:

SELECT * FROM cliente WHERE nome LIKE 'Rodrigo';

Where com outros operadores MySQL

Só como observação, o Oracle também exibe o valor NULL para especificar campos com ausência de dados, mas o SQL Server não exibe nada nesses campos, então se você estiver fazendo uso desse SGBD da Microsoft, fique sempre atento e não confunda um valor NULL com uma string vazia “”. A string vazia está lá! Ela existe! O valor NULL representa ausência total de informação.

Muito bem, agora que já sabemos o que é um campo NULL, vamos a um exemplo prático. Imaginem que queiramos exibir dados como "nome", "email" e "idade" de todos os usuários cujas idades cadastradas no banco NÃO sejam nulas. Nosso comando ficará assim:

SELECT nome AS Nome, email AS Email, idade AS Idade FROM cliente WHERE idade IS NOT NULL;

Where com outros operadores MySQL

Percebam que os dados do cliente "Rodrigo", cuja idade está cadastrada como nula, não foram exibidos. Agora vou inverter o comando, para que SOMENTE as idades nulas sejam exibidas.

SELECT nome AS Nome, email AS Email, idade AS Idade FROM cliente WHERE idade IS NULL;

Where com outros operadores MySQL

Notem que agora apenas os dados do cliente Rodrigo, cuja idade é nula no banco, foram exibidos.

Apenas para citar outro exemplo importante desse operador, mas que não veremos agora para não interromper a ordem dos assuntos, nós poderíamos querer fazer a média de todas as idades efetivamente cadastradas no sistema, desconsiderando os usuários cujos valores desse campo sejam nulos. Isso seria facilmente realizado com a verificação de “IS NOT NULL”, conforme utilizamos aqui. Mas voltaremos a falar dela no futuro.

Para encerrar, vou demonstrar o operador IN em ação. Como foi dito no início deste tutorial, ele nos permite efetuar uma busca dentre alguns elementos pré-determinados. Como nossa base de dados também possui a tabela "filme", vamos inserir alguns dados nela para que não usemos sempre a tabela cliente nas demonstrações.

INSERT INTO filme VALUES (“Drama”, “Cidade de Deus”, 1);

INSERT INTO filme VALUES (“Drama”, “O Pianista”, 2);

INSERT INTO filme VALUES (“Drama”, “Sangue Negro”, 3);

INSERT INTO filme VALUES (“Infantil”, “Shrek”, 4);

INSERT INTO filme VALUES (“Aventura”, “Quase Famosos”, 5);

INSERT INTO filme VALUES (“Aventura”, “Avatar”, 6);

INSERT INTO filme VALUES (“Terror”, “Sexta-Feira 13”, 7);

INSERT INTO filme VALUES (“Terror”, “Brinquedo Assassino”, 8);

Nossa tabela de filmes agora possui os seguintes dados:

Where com outros operadores MySQL

Agora vamos imaginar que queiramos efetuar uma consulta nos filmes do gênero "Drama". Podemos fazer isso com o operador IN da seguinte forma:

SELECT * FROM filme WHERE genero IN (‘Drama’);

Where com outros operadores MySQL

Poderíamos ainda especificar mais de um gênero, apenas separando-os por vírgulas dentro dos parênteses, dessa forma:

SELECT * FROM filme WHERE genero IN ('Drama', 'Terror');

Where com outros operadores MySQL

Agora foram exibidos tanto os filmes do gênero Drama quanto Terror. Bem, mas aí você, que está bem atento a todos os tópicos pode pensar que é desnecessário utilizar o operador IN, pois poderíamos obter o mesmo resultado com o LIKE e o OR, da seguinte maneira:

SELECT * FROM filme WHERE genero LIKE ‘Drama’ OR genero LIKE ‘Terror’;

Vamos executar:

Where com outros operadores MySQL

Realmente é fácil notar que as tuplas retornadas pelo banco são as mesmas. Para essa consulta, considerada simples, o IN pôde ser substituído pela combinação LIKE + OR, mas existirão situações em que isso não será possível, quando as consultas não forem tão simples e estiverem envolvendo mais de uma tabela. Chegaremos lá! Por enquanto apenas acredite que o operador IN é muito importante.




Algumas notícias

O que acontece com o cérebro no exato momento em que morremos

O que passa em nossa cabeça no momento da morte? Não se sabe exatamente e, embora os cientistas tenham alguma resposta, a resposta continua sendo um grande mistério. Além de difícil solução, tentar respondê-la pode criar implicações éticas. No entanto, uma equipe de cientistas da Universidade...

Ler Notícia Completa

Operada e devolvida ao útero, menina que nasceu duas vezes hoje 'acorda sorrindo toda manhã'

Um bebê pode nascer duas vezes? Não é o caso da absoluta maioria das crianças, mas foi assim para a pequena Lynlee Boemer. Em outubro de 2015, sua mãe, Margaret Boemer, descobriu que estava grávida de gêmeos. Ela sofreu um aborto espontâneo, mas um dos bebês sobreviveu. Com dez semanas de ges...

Ler Notícia Completa

Médicos dizem estar perto de chegar a exame de sangue para todos os tipos de câncer

Cientistas dizem que estão mais perto de criar um exame de sangue universal, capaz de identificar todos os tipos de câncer. Estudo conduzido com 1.005 pacientes por uma equipe da Universidade Johns Hopkins, dos Estados Unidos, testou um método que detecta oito tipos de proteínas e 16 mutações ge...

Ler Notícia Completa

Formato JPEG está com os dias contados

Há quantos anos você ouve falar em arquivos JPG? O formato já era utilizado nos primórdios da web comercial nos anos 1990, vivendo há mais de 20 anos como o principal método de compressão de imagens do público. No que depender de Google, Mozilla e outras empresas, isso pode mudar dentro de algum...

Ler Notícia Completa

EUA aprovam 'droga viva', 1ª terapia contra câncer que reestrutura sistema imunológico do paciente

Os Estados Unidos aprovaram o primeiro tratamento que reestrutura o sistema imunológico do paciente para atacar o câncer. A agência reguladora de medicamentos do país - a FDA - diz que a decisão foi um momento "histórico" e que a medicina agora "entra em uma nova fronteira". A companhia Novar...

Ler Notícia Completa

Cientistas norte-americanos criaram anticorpo capaz de atacar 99% das variações de HIV

Um grupo formado por pesquisadores do Instituto Nacional de Saúde (NIH), dos Estados Unidos, e da empresa farmacêutica Sanofi criaram em laboratório anticorpos superdesenvolvidos capazes de atacar 99% das cepas de HIV. O feito é ainda mais significativo por ser capaz até mesmo de prevenir a infec...

Ler Notícia Completa

Facebook investirá mais de US$ 1 bilhão em conteúdo original em 2018

Anunciada em agosto, a plataforma original de vídeos do Facebook, Watch, parece ser a grande aposta de Mark Zuckerberg para o ano que vem. De acordo com o TechCrunch, a empresa deve investir US$ 1 bilhão para criar e incentivar iniciativas voltadas para a produção de conteúdo audiovisual exclu...

Ler Notícia Completa

Software da Adobe é capaz de manipular gravações de voz e criar frases com perfeição

O software se chama Voco, foi desenvolvido pela Adobe (a mesma criadora do Photoshop) e permite manipular gravações de voz com uma precisão inédita, inclusive criando frases que a pessoa não disse. Na demonstração do app, um técnico forjou uma gravação em que um homem dizia “eu beijei a Jordan...

Ler Notícia Completa

Games nos Jogos Olímpicos de 2024. Será?

Sabe aquela discussão sobre os jogos eletrônicos poderem ou não ser considerados esportes? Pois o comitê responsável pela realização dos Jogos Olímpicos de 2024 acaba de colocar mais um pouco de lenha nesta fogueira. Isso aconteceu através da divulgação de que eles gostariam de incorporar torne...

Ler Notícia Completa

Algoritmo de Inteligência artificial sabe quando você está sonhando

Pesquisadores da Divisão de Medicina do Sono do Hospital Geral de Massachusetts desenvolveram um algoritmo capaz de identificar quando uma pessoa está sonhando. A tecnologia usa sinais de rádio frequência, através de um dispositivo semelhante a um roteador Wi-Fi, para monitorar a pessoa durante...

Ler Notícia Completa
Você gostará destes vídeos: