Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

borntkteam@hotmail.com

Exibição

Recommended Posts

Bom dia tenho o seguinte codigo abaixo aonde quando eu clico em cima do Colaborador o mesmo expande a tabela para abaixo so que eu quero que quando eu clique ele mostre somente o registro do colaborador como está ele mostra tudo nao sei como eu passo a variavel clicando no link via jquery segue o codigo

<body><?php include"topo.php";?><?phpinclude"config.php";?> <div class="container">    <h2>Lista Efetivo</h2>  <p>Segue lista efetivo :</p>  <div class="select">    <form method="POST" action="">  Colaborador :   <input type="text" name="busca" class="select">  <input type="submit" value="Buscar" name="ok"></form> <form action="" method="POST"><select name="categoria" class="select">  <option value="ativo" >Ativo</option>  <option value="vencida">Vencida</option></select><input type="submit" Value="Buscar" /></form> </div> <div class="links"> <table class="table table-striped">    <thead>      <tr>        <th>Nome</th>        <th>Função</th>        <th>Setor</th>        <th>Obra</th>        <th>Situação Pessoa</th>      </tr>    </thead>    <tbody>    <tr>        <?php		$categoria= @$_POST['categoria'];		$busca = @$_POST['busca'];// pega os dados recebido no campo busca		$exec = mysql_query("SELECT * from cadastro_pessoa ORDER BY `nome` ASC;") or die (mysql_error());while ($mostrar = mysql_fetch_assoc($exec)){	echo '<tr>';	//echo '<th>' . $mostrar['codigo'] . '</td>';    echo '<th><a iid="1" >'. $mostrar['nome'] .'</a></th>';	echo '<th>' . $mostrar['funcao'] . '</th>';	echo '<th>' . $mostrar['setor'] . '</th>';	echo '<th>' . $mostrar['obra'] . '</th>';	echo '<th>' . $mostrar['situacao_pessoa'] . '</th>';}?></tbody></table><script>  $(".links a").click(function(){    $("#item"+$(this).attr("iid")).slideToggle("fast");});</script><div id="item1" class="item">  <table class="table table-striped">    <thead>      <tr>        <th>Nome</th>        <th>Função</th>        <th>Setor</th>        <th>Obra</th>        <th>Situação Pessoa</th>        <th>Norma</th>        <th>Data Vigor </th>        <th>Situação Norma</th>        <th>Validade</th>        <th>Dias Restantes</th>         <th>Certificado</th>      </tr>    </thead>    <tbody>      <tr>        <?php		$categoria= @$_POST['categoria'];		$busca = @$_POST['busca'];// pega os dados recebido no campo busca		$exec = mysql_query("SELECT NCP.codigo,       NCP.codigo_norma,       NCP.codigo_cadastro_pessoa,       NCP.data_atual_norma,       NCP.situacao_norma_pessoa,	   NCP.dias_restante,       N.norma,       N.validade,       C.nome,       C.setor,       C.funcao,       C.obra,	   C.situacao_pessoa,	   U.fileFROM normas_cadastro_pessoa NCP	INNER JOIN normas N ON N.id_norma=NCP.codigo_norma	INNER JOIN cadastro_pessoa C ON C.codigo_pessoa=NCP.codigo_cadastro_pessoa	INNER JOIN uploads U ON U.id=NCP.codigo	ORDER BY `nome` ASC;") or die (mysql_error());while ($mostrar = mysql_fetch_assoc($exec)){		$situacao= $mostrar['situacao_norma_pessoa'];	if ($situacao == 'Ativo'){// faz a verificaçao e altera a class do botao	$btn="btn btn-success btn-sm";	} else {		$btn="btn btn-danger btn-sm";	}	echo '<tr>';	//echo '<th>' . $mostrar['codigo'] . '</td>';    echo '<th>' . $mostrar['nome'] . '</th>';	echo '<th>' . $mostrar['funcao'] . '</th>';	echo '<th>' . $mostrar['setor'] . '</th>';	echo '<th>' . $mostrar['obra'] . '</th>';	echo '<th>' . $mostrar['situacao_pessoa'] . '</th>';    echo '<th>' . $mostrar['norma'] . '</th>';    echo '<th>' . $mostrar['data_atual_norma'] . '</th>';    echo '<th><button type="button" class="'.$btn.'">'.$mostrar['situacao_norma_pessoa'].'</button></th>';	echo '<th>' . $mostrar['validade'] . ' dias</th>';	echo '<th>' . $mostrar['dias_restante'] .'dias</th>';	echo '<th><a href="uploads/'.$mostrar['file'].'" target="_blank">view file</a></th>';	// codigo abaixo faz a comparação da validade do cadastro norma com o lançamento	$data_geracao =$mostrar['data_atual_norma']; // recebe da coluna data atual norma	$data = explode("-",$data_geracao);$dia =  $data[2];$mes = $data[1];$ano =  $data[0];$dias_vencimento = $mostrar['validade']; $data_vencimento = date("Y-m-d", mktime (0, 0, 0, $mes, $dia+$dias_vencimento, $ano));$data_hoje = date("Y-m-d");$codigo= $mostrar['codigo'];////faz comparação dos dias e insere os dias restantes no banco de dados$datetime2 = new Datetime ($data_vencimento);$datetime1 = new datetime ($data_hoje);$interval = $datetime1->diff($datetime2);$dias_restantes =$interval->format('%r%a ');////executa a query com os dias restante e grava no banco!$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET dias_restante='$dias_restantes' WHERE codigo= '$codigo'")or die (mysql_error());//if ($data_hoje <= $data_vencimento) {	 $exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET situacao_norma_pessoa='Ativo' WHERE codigo= '$codigo'")or die (mysql_error());}else {	$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET situacao_norma_pessoa='Vencida' WHERE codigo= '$codigo'")or die (mysql_error());}}//SELECT `normas_cadastro_pessoa`.*,`normas`.`validade` FROM `normas_cadastro_pessoa`//INNER JOIN `normas` ON `normas_cadastro_pessoa`.`codigo_norma` = `normas`.`id_norma ?> </tbody></table></div></div></div></div></body><?php include"rodape.php"?></html>

20kxjz6.jpg

 

 

alguem ?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Quando você clica no nome do colaborador, ele expande esse tabela completa para baixo? Se sim, procura no SELECT da tabela.

 

A solução para mim, é você fazer 2 SELECTS: um somente com os dados essenciais e o outro com os dados completos mas daquele DETERMINADO COLABORADOR.

Compartilhar este post


Link para o post
Compartilhar em outros sites

então quando eu clico ele expande eu nao sei como eu faço para quando eu clicar em cima do colaborador eu jogar um valor para meu select e usar where nome = '$nome' creio que deve ser feito via codigo jquery mais não sei como proceder pois do geito que está ele somente expande e esconde a tabela sem jogar parametro

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acredito que o seu PHP está errado. Você tem que fazer uma consulta para listar todos os colaboradores, e depois outra consulta para listar os colaboradores repetidos pelo ID. Pelo seu código, você está fazendo 2 buscas.

 

Mas tente fazer o seguinte. Depois dessa parte:

 <?php
		$categoria= @$_POST['categoria'];
		$busca = @$_POST['busca'];// pega os dados recebido no campo busca
		$exec = mysql_query("SELECT * from cadastro_pessoa ORDER BY `nome` ASC;") or die (mysql_error());
while ($mostrar = mysql_fetch_assoc($exec)){

Adicione isso:

$id_col = $linha['codigo'];

Agora, na segunda consulta, deixe assim:

<?php
		$exec2 = mysql_query("SELECT NCP.codigo,
       NCP.codigo_norma,
       NCP.codigo_cadastro_pessoa,
       NCP.data_atual_norma,
       NCP.situacao_norma_pessoa,
	   NCP.dias_restante,
       N.norma,
       N.validade,
       C.nome,
       C.setor,
       C.funcao,
       C.obra,
	   C.situacao_pessoa,
	   U.file
FROM normas_cadastro_pessoa NCP
	INNER JOIN normas N ON N.id_norma=NCP.codigo_norma
	INNER JOIN cadastro_pessoa C ON C.codigo_pessoa=NCP.codigo_cadastro_pessoa
	INNER JOIN uploads U ON U.id=NCP.codigo
	WHERE NCP.codigo = '$id_col' ") or die (mysql_error());
while ($mostrar2 = mysql_fetch_assoc($exec2)){

Tente isso. Observe que mudei a variável para mostrar os resultados. Mude também na sua segunda consulta.

Compartilhar este post


Link para o post
Compartilhar em outros sites


 

 

<body>

<?php include"topo.php";?>

<?php

include"config.php";

?>

 

<div class="container">

<h2>Lista Efetivo</h2>

<p>Segue lista efetivo :</p>

<div class="select">

<form method="POST" action="">

Colaborador : <input type="text" name="busca" class="select">

<input type="submit" value="Buscar" name="ok">

</form>

<form action="" method="POST">

<select name="categoria" class="select">

<option value="ativo" >Ativo</option>

<option value="vencida">Vencida</option>

</select>

<input type="submit" Value="Buscar" />

</form>

</div>

<div class="links">

<table class="table table-striped">

<thead>

<tr>

<th>Nome</th>

<th>Função</th>

<th>Setor</th>

<th>Obra</th>

<th>Situação Pessoa</th>

<th>Resumo Normas</th>

</tr>

</thead>

<tbody>

<tr>

<?php

//$query= mysql_query("SELECT * from cadastro_pessoa ORDER BY `nome` ASC; ");

//while ($mostrar2 = mysql_fetch_assoc($query)){

//$nome = $mostrar2['nome'];

//$categoria= @$_POST['categoria'];

//$busca = @$_POST['busca'];// pega os dados recebido no campo busca

 

$exec = mysql_query("SELECT

NCP.codigo_cadastro_pessoa,

NCP.situacao_norma_pessoa,

N.norma,

C.nome,

C.setor,

C.funcao,

C.obra,

C.situacao_pessoa

FROM normas_cadastro_pessoa NCP

INNER JOIN normas N ON N.id_norma=NCP.codigo_norma

INNER JOIN cadastro_pessoa C ON C.codigo_pessoa=NCP.codigo_cadastro_pessoa

group by nome

") or die (mysql_error());

while ($mostrar = mysql_fetch_assoc($exec)){

$id_col = $mostrar['codigo_cadastro_pessoa'];

$nome = $mostrar['nome'];

echo '<tr>';

//echo '<th>' . $mostrar['codigo'] . '</td>';

echo '<th><a iid="1" >'. $mostrar['nome'] .'</a></th>';

echo '<th>' . $mostrar['funcao'] . '</th>';

echo '<th>' . $mostrar['setor'] . '</th>';

echo '<th>' . $mostrar['obra'] . '</th>';

echo '<th>' . $mostrar['situacao_pessoa'] . '</th>';

//}

$exec2 = mysql_query("SELECT

NCP.codigo_cadastro_pessoa,

NCP.situacao_norma_pessoa,

N.norma,

C.nome,

C.setor,

C.funcao,

C.obra,

C.situacao_pessoa

FROM normas_cadastro_pessoa NCP

INNER JOIN normas N ON N.id_norma=NCP.codigo_norma

INNER JOIN cadastro_pessoa C ON C.codigo_pessoa=NCP.codigo_cadastro_pessoa

WHERE NCP.codigo_cadastro_pessoa = '$id_col'

") or die (mysql_error());

while ($mostra = mysql_fetch_assoc($exec2)){

$situacao= $mostra['situacao_norma_pessoa'];

 

 

if ($situacao == 'Vencendo') {

$btn="btn btn-warning btn-sm";

}else

 

if ($situacao == 'Ativo'){// faz a verificaçao e altera a class do botao

$btn="btn btn-success btn-sm";

} else {

$btn="btn btn-danger btn-sm";

}

//echo '<th>' . $mostra['norma'] . $mostra['situacao_norma_pessoa'] .'</th>';

echo '<th><button type="button" class="'.$btn.'">'.$mostra['norma'].'</button></th>';

 

 

}

 

}

?>

 

</tbody>

</table>

<div id="item1" class="item">

<script>

$(".links a").click(function(){

$("#item"+$(this).attr("iid")).slideToggle("fast");

});

</script>

 

<table class="table table-striped">

<thead>

<tr>

<th>Nome</th>

<th>Função</th>

<th>Setor</th>

<th>Obra</th>

<th>Situação Pessoa</th>

<th>Norma</th>

<th>Data Vigor </th>

<th>Situação Norma</th>

<th>Validade</th>

<th>Dias Restantes</th>

<th>Certificado</th>

</tr>

</thead>

<tbody>

<tr>

 

<?php

$exec4 = mysql_query("SELECT NCP.codigo,

NCP.codigo_norma,

NCP.codigo_cadastro_pessoa,

NCP.data_atual_norma,

NCP.situacao_norma_pessoa,

NCP.dias_restante,

N.norma,

N.validade,

C.nome,

C.setor,

C.funcao,

C.obra,

C.situacao_pessoa,

U.file

FROM normas_cadastro_pessoa NCP

INNER JOIN normas N ON N.id_norma=NCP.codigo_norma

INNER JOIN cadastro_pessoa C ON C.codigo_pessoa=NCP.codigo_cadastro_pessoa

INNER JOIN uploads U ON U.id=NCP.codigo

WHERE NCP.codigo_cadastro_pessoa = '$id_col'

") or die (mysql_error());

 

while ($mostrar = mysql_fetch_assoc($exec4)){

 

$situacao= $mostrar['situacao_norma_pessoa'];

if ($situacao == 'Vencendo') {

$btn="btn btn-warning btn-sm";

}else

if ($situacao == 'Ativo'){// faz a verificaçao e altera a class do botao

$btn="btn btn-success btn-sm";

} else {

$btn="btn btn-danger btn-sm";

}

echo '<tr>';

//echo '<th>' . $mostrar['codigo'] . '</td>';

echo '<th>' . $mostrar['nome'] . '</th>';

echo '<th>' . $mostrar['funcao'] . '</th>';

echo '<th>' . $mostrar['setor'] . '</th>';

echo '<th>' . $mostrar['obra'] . '</th>';

echo '<th>' . $mostrar['situacao_pessoa'] . '</th>';

echo '<th>' . $mostrar['norma'] . '</th>';

echo '<th>' . $mostrar['data_atual_norma'] . '</th>';

echo '<th><button type="button" class="'.$btn.'">'.$mostrar['situacao_norma_pessoa'].'</button></th>';

echo '<th>' . $mostrar['validade'] . ' dias</th>';

echo '<th>' . $mostrar['dias_restante'] .'dias</th>';

echo '<th><a href="uploads/'.$mostrar['file'].'" target="_blank">view file</a></th>';

 

// codigo abaixo faz a comparação da validade do cadastro norma com o lançamento

$data_geracao =$mostrar['data_atual_norma']; // recebe da coluna data atual norma

$data = explode("-",$data_geracao);

$dia = $data[2];

$mes = $data[1];

$ano = $data[0];

$dias_vencimento = $mostrar['validade'];

$data_vencimento = date("Y-m-d", mktime (0, 0, 0, $mes, $dia+$dias_vencimento, $ano));

$data_hoje = date("Y-m-d");

$codigo= $mostrar['codigo'];

//

//faz comparação dos dias e insere os dias restantes no banco de dados

$datetime2 = new Datetime ($data_vencimento);

$datetime1 = new datetime ($data_hoje);

$interval = $datetime1->diff($datetime2);

$dias_restantes =$interval->format('%r%a ');

//

//executa a query com os dias restante e grava no banco!

$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET dias_restante='$dias_restantes' WHERE codigo= '$codigo'")or die (mysql_error());

//

 

 

if ($data_hoje <= $data_vencimento) {

$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET situacao_norma_pessoa='Ativo' WHERE codigo= '$codigo'")or die (mysql_error());

 

}elseif ($data_hoje > $data_vencimento){

$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET situacao_norma_pessoa='Vencida' WHERE codigo= '$codigo'")or die (mysql_error());

}

else

$exec2 = mysql_query("UPDATE normas_cadastro_pessoa SET situacao_norma_pessoa='Vencendo' WHERE codigo= '$codigo'")or die (mysql_error());

}

 

//SELECT `normas_cadastro_pessoa`.*,`normas`.`validade` FROM `normas_cadastro_pessoa`

//INNER JOIN `normas` ON `normas_cadastro_pessoa`.`codigo_norma` = `normas`.`id_norma

 

?>

 

</tbody>

</table>

 

</div>

</div>

</div>

</div>

</body>

 

</html>

<?php include"rodape.php"?>

</html>

Compartilhar este post


Link para o post
Compartilhar em outros sites

As duas consultas estão iguais, acho que você confundiu. Era apenas pra você adicionar depois do WHILE, esse código:

 

$id_col = $mostrar['codigo'];

 

A consulta tem que estar do mesmo jeito que você abriu o tópico.

Compartilhar este post


Link para o post
Compartilhar em outros sites

As duas consultas estão iguais, acho que você confundiu. Era apenas pra você adicionar depois do WHILE, esse código:

 

 

A consulta tem que estar do mesmo jeito que você abriu o tópico.

 

é que na tabela cadastro_pessoa o campo id é codigo_pessoa e nao codigo

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Tudo bem pessoal?
       
      No código abaixo, estou fazendo uma consulta nas tabelas, banners e banners_referencia
      Meu objetivo é trazer resultados com valores iguais ao nome da cidade declarada na $cidade ou resultados com a referencia Total.
      O problema é que está trazendo todos os resultados. Tenho 10 linhas, 1 com o nome da cidade e duas com o valor Total, então o resultado teria que ser de apenas 3 linhas, mas mostra tudo.
       
      $banner = "SELECT A.*, B.* FROM banners A, banners_referencia B WHERE B.cod_referencia = A.cod_referencia AND A.cidade = '$cidade' OR B.referencia = 'Total' ORDER BY RAND()";
      $banner = mysqli_query($conexao, $banner) or die ("Banner não encontrado");
      while($busca= mysqli_fetch_array($banner)){
          print $busca['cidade'].'<br>';
      };
       
      Alguém consegue me ajudar?
    • Por Rafael_Ferreira
      Não consigo carregar a imagem do captcha do meu formulário. Foi testado com o xampp e easyphp. Também não carregou a imagem de outros captcha. 
       
       
    • Por luiz monteiro
      Olá, tudo bem?
       
      Estou melhorando meu conhecimento em php e mysql e, me deparei com o seguinte. A tabela da base de dados tem um campo do tipo varchar(8) o qual armazena números. Eu não posso alterar o tipo desse campo. O que preciso é fazer um select para retornar o números que contenham zeros a direita ou a esquerda.
      O que tentei até agora
       
      Ex1
      $busca = $conexao->prepare("select campo form tabela where (campo = :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form']);
       
      Se a direita da string $_REQUEST['campo_form'] termina ou inicia com zero ou zeros, a busca retorna vazio.
      Inseri dados numéricos, da seguinte maneira para testar: 01234567;  12345670: 12345678: 12340000... entre outros nessa coluna. Todos os valores que não terminam ou não iniciam com zero ou zeros, o select funciona.
       
       
      Ex2
      $busca = $conexao->prepare("select campo form tabela where (campo = 0340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex3
      $busca = $conexao->prepare("select campo form tabela where (campo = '02340001' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex4
      $busca = $conexao->prepare("select campo form tabela where (campo like 2340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex5
      $busca = $conexao->prepare("select campo form tabela where (campo like '12340000') ");
      Esse número está cadastrado, mas não retorna.
       
      Ex6
      $busca = $conexao->prepare("select campo form tabela where (campo like '"12340000"' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex7
      $busca = $conexao->prepare("select campo form tabela where (campo like :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form'])
      Não retorna dados.
       
      O  $_REQUEST['campo_form'] é envio via AJAX de um formulário. 
      Usei o gettype para verificar o post, e ele retorna string.
      Fiz uma busca com número 12345678 para verificar o que o select retorna, e também retrona como string.
       
      Esse tipo de varchar foi usado porque os números que serão gravados nesse campo,  terão zeros a direita ou na esquerda. Os tipos number do mysql não gravam zeros, então estou usando esse. O problema é a busca.
      Agradeço desde já.
       
       
    • Por daemon
      Boa tarde,
       
      Eu tenho uma rotina que faz uma leitura do arquivo .xml de vários sites.

      Eu consigo pegar o tópico e a descrição, e mostrar a imagem que esta na pagina do link.
      Para isso utilizo esta função:
      function getPreviewImage($url) { // Obter o conteúdo da página $html = file_get_contents($url); // Criar um novo objeto DOMDocument $doc = new DOMDocument(); @$doc->loadHTML($html); // Procurar pela tag meta og:image $tags = $doc->getElementsByTagName('meta'); foreach ($tags as $tag) { if ($tag->getAttribute('property') == 'og:image') { return $tag->getAttribute('content'); } } // Se não encontrar og:image, procurar pela primeira imagem na página $tags = $doc->getElementsByTagName('img'); if ($tags->length > 0) { return $tags->item(0)->getAttribute('src'); } // Se não encontrar nenhuma imagem, retornar null return null; } // Uso: $url = "https://example.com/article"; $imageUrl = getPreviewImage($url); if ($imageUrl) { echo "<img src='$imageUrl' alt='Preview'>"; } else { echo "Nenhuma imagem encontrada"; }  
      Mas estou com um problema, esta funcão funciona quando coloco em uma pagina de teste.php. Preciso mostrar em uma página inicial diversas fotos de todos os links. (No caso acima só funciona 1).
×

Informação importante

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