Ir para conteúdo
Artur Mendonça

Preencher listagem depois de selecionar valor em campo select

Recommended Posts

Olá amigos,

criei uma página para fazer a inscrição de "atletas" (leia-se crianças) em provas desportivas.

A página criada é a que está em anexo.

 

Queria que ao abrir a página a listagem com o nome dos atletas ficasse em branco e só aparecesse os nomes depois de selecionar a prova em que se inscrevem.

 

Na coluna "inscrito" queria que aparecesse "Sim" ou "Não" no caso do atleta já estar inscrito ou não.

Depois, ao clicar no botão "inscrever" a coluna "inscrito" seria atualizada para "Sim" e ao clicar em "Anular" seria atualizado para "Não".

 

Tenho as tabelas "tblatletas2" (com o nome de todos os atletas do grupo), "tblprova" (com todas as provas existentes) e "tblinscprova" (que será preenchida com os dados dos atletas inscritos; nesta tabela tem os campos "Prova" e "Atleta").

 

Neste momento tenho o seguinte código, mas que não funciona como pretendo.

  <?php
  include_once("administrativo.php");
  $resulta	= mysqli_query($conectar,"SELECT * FROM tblatleta2 ORDER BY Nome");
  $linhas 	= mysqli_num_rows($resulta);
  
  $inscrito = mysqli_query($conectar, "SELECT * FROM tblinscprova WHERE Prova = 'prova' AND Atleta='IdAtleta'");
  
  
 ?>
 <head>
    <meta charset="utf-8">
	
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags -->
    <meta name="description" content="">
    <meta name="author" content="">
    <link rel="icon" href="adm/imagens/teste.ico">
</head>	
 
    <div class="container theme-showcase" role="main">

     <!-- Lista de utilizadores -->
      <div class="page-header"> <br />
        <h1>Inscrever Atletas em Provas</h1>
      </div>
	   
 <div class="form-group">
    <label for="inputEmail3" class="col-sm-2 control-label">Prova em que o atleta se inscreve </label>
    <div class="col-sm-10">
    
	<select class="form-control" name="prova" required>
  <option></option>
  <?php $resultado=mysqli_query($conectar, "SELECT * FROM tblprova ORDER BY DataProva");
		WHILE($dados = mysqli_fetch_assoc($resultado)){?>
		<option value="<?php echo $dados['IdProva'];?>"> <?php echo $dados['NomeProva'];?></option>
		<?php } ?>
</select>

 </div>
  </div>
      <div class="row">
        <div class="col-md-12">
          <table class="table">
            <thead>
              <tr>
                <th>ID </th>
                <th>Nome</th>
                <th>Opções</th>
				<th>Inscrito</th>
				<!-- <th>Foto</th> -->
              </tr>
            </thead>
            <tbody>
			
	
            <?php
			 
              while($linhas = mysqli_fetch_array($resulta)){
				$naame  	= $linhas['Nome'];
				$noome  	= base64_decode($naame);
                 echo "<tr>";
                 echo "<td>".$linhas['IdAtleta']."</td>";
                 echo "<td>".$noome."</td>";
				 //echo "<td>".Não."</td>";
				
				?>
				<td>

				<a href='administrativo.php?link=12&IdAtleta=<?php 
				echo $linhas['IdAtleta'];?>'> <button type='button'
                class='btn btn-xs btn-primary'>Inscrever</button></a>

                <a href='processa/proc_apagar_atleta.php?IdAtleta=<?php 
				 echo $linhas['IdAtleta'];?>'><button type='button' class='btn btn-xs
                 btn-danger'>Anular</button></a>
				
				
				<?php
                
                 echo "</tr>";
              }
            ?>
          </tbody>
          </table>
        </div>
          </div>
    </div> <!-- /container -->

Podem ajudar-me?

 

Muito obrigado, desde já.

Sem Título.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Apenas uma idéia, ver o que você acha.

 

Saca bem de jquery ?

 

Você pode verificar se o campo select está retornando algum valor, se estiver vazio, você esconde o elemento da tabela, caso contrario, se tiver valor, você coloca pra exibir os dados desse valor selecionado. Essa idéia foi uma que eu tive agora, pode ser que tenham outras. Com ANGULAR seria mole fazer isso.

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 eduardohaag
      Boa noite pessoal,
      Esbarrei em um novo problema com consultas no meu sistema.
       
      Tenho um formulário no sistema que deverá apresentar todos os materiais utilizados em uma determinada Venda e seus respectivos estoques obtidos através da soma das entradas e saidas do estoque.
      Para isso devo buscar os dados em 3 tabelas do banco de dados sendo elas VendasProdutos, Composicao,  Materiais e Estoque

       
      Eis que surge meu problema, como posso ter vários produtos na venda e alguns produtos usam os mesmos materiais, a consulta está retornando com os materiais duplicados, quando o que eu gostaria era que somasse de acordo com cada material.
       
      A query que estou usando para teste no acesso é a seguinte:
      SELECT Composicao.IdMaterial, materiais.descricao, Sum(Estoque.Quantidade) AS Estoque, [VendasProdutos]![Quantidade]*[Composicao]![Quantidade] AS TotalUtilizado FROM (VendasProdutos LEFT JOIN (materiais RIGHT JOIN Composicao ON materiais.ID = Composicao.IdMaterial) ON VendasProdutos.IdProduto = Composicao.IdProduto) LEFT JOIN Estoque ON materiais.ID = Estoque.IdMaterial GROUP BY Composicao.IdMaterial, materiais.descricao, [VendasProdutos]![Quantidade]*[Composicao]![Quantidade], VendasProdutos.IdVenda HAVING (((VendasProdutos.IdVenda)=1));  
      A consulta está retornando os dados dessa forma:

       
      E eu gostaria de que agrupasse por ex:
       
      ID                Descricao                Estoque               TotalUtilizado
      1                 Capa Agenda             34                             10
      2                 Miolo Agenda            27                              5
       
      Alguem Sabe como posso fazer isso?
      Desulpem pelo post gigante, mas não sabia como explicar melhor.
    • Por felipotrindade
      Galera boa noite! Preciso de uma ajuda de vocês com relação a um comando SQL no MySQL e depois no PHP.
      Tenho as seguintes tabelas e as suas colunas:
      Pessoa
       ID
       Nome
       
      Tratamento
       ID
       DESCRICAO
       
      ROTINAS
       ID
       ID_PESSOA
       ID_TRATAMENTO
       
      Por exemplo, quando eu insiro os registros nessas tabelas, onde, a rotina manterá o relacionamento entre pessoa e tratamento conforme abaixo:
      ROTINAS
      ID = 1 ID_PESSOA = 1 ID_TRATAMENTO = 1
      ID = 2 ID_PESSOA = 1 ID_TRATAMENTO = 2
       
      Supondo que, a pessoa se chame JOÃO, ou seja, ele aparece duas vezes na tabela rotinas conforme acima e, o tratamento 1 seja medição do nível de ph e o tratamento 2 seja temperatura da água. Usando o inner join fica assim:
      PESSOA TRATAMENTO.DESCRICAO
      JOÃO      MEDIÇÃO PH
      JOÃO      TEMPERATURA
       
      mysql> select pessoa.nome, tratamento.descricao from rotinas inner join pessoa on rotinas.id_pessoa=pessoa.id inner join tratamento on rotinas.id_tratamento=tratamento.id;
       
      Até ai tudo bem!!! Porém, ao invés de mostrar o comando select com os resultados linhas por linha, gostaria de agrupar pelo nome da pessoa e mostrar os tratamentos, no caso a descrição e colunas e não linha a linha repetindo o nome da pessoa várias vezes.
       
      Não sei se deu para entender! Peço desculpas por tentar explicar dessa forma rs.....
       
      Obrigado se puderem me ajudar!!!
    • Por Félix Henrique
      Boa noite nobres amigos.

      Estou com um problema em meu sisteminha, e não estou sabendo como resolver.

      Segue o link do sistema em funcionamento:
       
      http://locarweb.com.br/cotacao/

      O que eu queria?
      Que ao selecionar um tipo de sementes no 1º select, ele me desse as variedades de sementes disponíveis para esse tipo no 2º select.
      Seria estilo aqueles scripts de Estado/Cidade.

      Mas o que acontece?

      O problema maior ocorre quando vou duplicar a linha de pedidos, duplicando os selects acima.

      O erro acontece que você seleciona um tipo, mas fica disponível todas as variedades no próximo select.

      Seria tipo:
      TIPO ------------- > VARIEDADE
      Brachiara ------ > Decumbens
      Brachiara ------ > Brizantha

      Panicum ------ > Tanzânia
       
       
      Alguém poderia me ajudar a entender como faço para resolver esse problema?
       
    • Por Wictor Pamplona
      Olá, me chamo Wictor Pamplona e estou enfrentando um pequeno problema com HTML. Gostaria de pedir à ajuda de vocês para resolver essa questão.
       
      Veja, eu tenho um formulário aonde possuí vários SELECT, eu já produzi um código jQuery que faz a tradução deste select para HTML e altera o select ele estando oculto para o usuário, isto já está funcional. Porém, recentemente me surgiu a necessidade de inserir código HTML nestes options, tanto para ser imprimido como texto, como ser lido como html dentro da página.
      Sei que a dúvida parecer ser de javascript, porém não é (creio que possa ser resolvido com HTML).
       
      Vejamos, eu colocando o option assim:

      <option value=""><b>1-</b> Linha 1
      Eu queria que fosse traduzido para o select exatamente como foi escrito, sendo uma variável de texto não aplicando a estilização HTML: <b>1- Linha 1</b>.
      Porém, ainda assim apresenta só o texto sem o html, retornando no select apenas: 1- LInha 1, não imprimindo o html em texto.
    • Por mr22robot
      Estou com uma dúvida. É possível determinar um select a partir de uma escolha?
      Ex. 
      SELECT CASE WHEN a < b THEN select * from tabela1 WHEN d < e THEN select * form tabela2 END FROM tabela; Algo parecido. Se uma condição for atendida select1 , se outra condição for atendida: select2.
      O que acontece: estou com um relatorio que preciso criar no winthor e não consigo melhorar isso. Tenho de fazer três relatorios como solução. Se eu consigo implantar isso, eu faria somente um relatorio. 
      Tipo se marcar um campo, sai um relatorio. Se marcar outro, saí outro relatorio.
×

Informação importante

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