Ir para conteúdo
  • 0
gamesmax2

Obter dados de único nome MYSQL

Pergunta

Boa tarde,

Pessoal estou com uma dificuldade no MYSQL, estou querendo obter dados de um cadastro caso ele tenha preenchido todos os Campos, tentei usar o Group by mas não tive sucesso.

 

Minha tabela e a seguinte:

 

Nome.              Pedido.            Status

Daniel.              9955.                 Ok

Daniel.              9954                  Ok

Rafael.              9940                  Ok

Rafael.              9941.                 Aberto

Rafael.              9942.                 Ok

Rodrigo.            9961.                 Ok

Rodrigo.            9962.                 Ok

 

 

Meu objetivo e puxar os nomes que estão com todos o pedidos relacionado em ok, no caso o Rafael não pode aparece pois ele tem um pedido Aberto, porém não conseguir fazer isso, pessoal peco a ajuda de VCS muito o obrigado.

 

tentei isso aqui:


SELECT nome, pedido, status FROM `cadastros` GROUP BY  pedido, nome
ORDER BY having status = 'Ok'

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

7 respostas a esta questão

Recommended Posts

  • 0
SELECT nome, pedido, status
FROM `cadastros` c1
where not exists (SELECT 1
                  FROM `cadastros` c2
                  where c2.none = c1.nome
and  status = 'Aberto')
GROUP BY  pedido, nome
ORDER BY nome

 

O not exists verifica se o "nome" tem algum
status Aberto 

 

Mais detalhes

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0

Bom, se eu entendi e o caso for que o status não possa ser"OK". A coisa é meio óbvia:

SELECT nome, pedido, status FROM cadastros WHERE status != 'Ok'

Todos os dados de nome, pedido, status na tabela cadastros que não tiver com o status definido como Ok serão retornados

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0

Opa muito obrigado, funciona sim.:grin:

Só me ajuda em mais uma coisa se caso eu querer remover mais status além do aberto poderia fazer isso status status = 'aberto' or status = ' separação'

Tentei fazer isso não funciono, você teria algo pra me ajuda?

 

 

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0
7 minutos atrás, Omar~ disse:

Bom, se eu entendi e o caso for que o status não possa ser"OK". A coisa é meio óbvia:


SELECT nome, pedido, status FROM cadastros WHERE status != 'Ok'

Todos os dados de nome, pedido, status na tabela cadastros que não tiver com o status definido como Ok serão retornados

 

 

 

Omar, o problema e que vai puxa nome que não completou o cadastro dos pedidos, exemplo o Rafael tem 3 pedidos porém só 2 que estão OK, então ele não estão completo, meu interesse e puxar apenas nomes que tem todos os pedidos relacionado a ele que esteja com status Ok, o Daniel tem 2 pedidos relacionado a ele e estao Ok.

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0

Tem de ser um subselect pois se pediu um caso como " o Rafael não pode aparece pois ele tem um pedido Aberto " por linha não resolve, tem de ler as demais linhas.

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • Por ILR master
      Pessoal, pergunta bem simples. Abaixo tenho o seguinte código:
       
      <script>
      function alerta()
      {
        if (window.confirm("Você realmente quer sair?")) {
          window.open("sair.html");
      }
      }
      </script>
       
      Funciona perfeitamente, só que está abrindo em outra janela e quero que abra na mesma janela.
       
      Alguém pode me ajudar?
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.