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 ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
    • 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.
×

Informação importante

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