Ir para conteúdo
alan de souza arantes

Gero um relatório e quando o campo esta em branco ele preenche o campo com outra informação qualquer.

Recommended Posts

Boa tarde Galera!

 

Tenho um cod que extrai relatórios do MYSQL em forma de Excel, meu problema é que quando o campo que busco esta vazio ele preenche com outra informação qualquer.

Como eu resolvo isso?

 

<?php

include("../conexao_checkout.php");


session_start();

$usuario     = $_SESSION['UsuarioID'];
$usuario_nome  = $_SESSION['UsuarioNome'];
$ip      = $_SERVER["REMOTE_ADDR"];
$data_contratado       = date('Y-m-d H:i:s');

$exibicao   = $_POST["exibicao"];
$filtro     = $_POST["filtro"];
$entrega    = $_POST["entrega"];
$contrata   = $_POST["contrata"];

if ($filtro > 0) {
    $cli = " AND `id_cliente` = ".$filtro;
}else{
    $cli = "";
}

if ($entrega  != "") {
    $data2 = str_replace('/', '-', $entrega);
    $nova_data2 = strftime("%Y-%m-%d", strtotime($data2));
    $ent = "AND `prazo_entrega` LIKE '%".$nova_data2."%' ";
}else{
    $ent = "";
}

if ($contrata  != "") {
    $data1 = str_replace('/', '-', $contrata);
    $nova_data = strftime("%Y-%m-%d", strtotime($data1));
    $cont = "AND `contratacao` LIKE '%".$nova_data."%' ";
}else{
    $cont = "";
}


$results = mysqli_query($conexao, "SELECT * FROM `servicos_filiais` WHERE `tecnico_interno` = $usuario {$cli} {$ent} {$cont};");


echo '
    <table class="table table-hover" style="display: none;">
                <thead>
                    <th>ID</th>
                    <th>Ordem</th>
                    <th>COd Serviço</th>
                    <th>Nome Serviço</th>
                    <th>Cliente</th>
                    <th>Filial</th>
                    <th>Acompanhamento</th>
                    <th>Contratação</th>
                    <th>Solicitante</th>
                    <th>Coordenação</th>
                    <th>Técnico</th>
                    <th>Técnico interno</th>
                    <th>Total do Serviço</th>
                    <th>Total de Parcelas</th>
                    <th>Status</th>
                    <th>Observação</th>
                    <th>Data da Observação</th>                    
                </thead>
                <tbody>
                    
                
  ';

while ($row = mysqli_fetch_assoc($results)) {
    $id_cliente       = $row['id_cliente'];
    $id_servico_      = $row['id'];
    $id_filial        = $row['id_filial'];
    $id_coordenacao   = $row['coordenacao'];
    $id_tecnico       = $row['tecnico'];
    $id_tecnico_int   = $row['tecnico_interno'];
    $observacao       = $row['texto'];
    $data_3           = $row['data'];


    $consulta   = mysqli_query($conexao, "SELECT * FROM `clientes` WHERE `id` = {$id_cliente}; ");
    while ($row01 = mysqli_fetch_assoc($consulta)) {
        $nomedocliente = $row01['nome_cliente'];
    }
    $consulta01   = mysqli_query($conexao, "SELECT * FROM `filiais` WHERE `id` = {$id_filial}; ");
    while ($row02 = mysqli_fetch_assoc($consulta01)) {
        $nome_filial = $row02['nome_filial'];
    }
    $consulta02   = mysqli_query($conexao, "SELECT * FROM `login_funcionarios` WHERE `id` = {$id_coordenacao}; ");
    while ($row03 = mysqli_fetch_assoc($consulta02)) {
        $coordenacao = $row03['nome'];
    }
    $consulta03   = mysqli_query($conexao, "SELECT * FROM `login_funcionarios` WHERE `id` = {$id_tecnico}; ");
    while ($row04 = mysqli_fetch_assoc($consulta03)) {
        $tecnico = $row04['nome'];
    }

    $consulta04   = mysqli_query($conexao, "SELECT * FROM `login_funcionarios` WHERE `id` = {$id_tecnico_int}; ");
    while ($row05 = mysqli_fetch_assoc($consulta04)) {
        $tecnico_interno = $row05['nome'];
    }

    $consulta05   = mysqli_query($conexao, "SELECT * FROM `observacao_servicos` WHERE `id_servico` = {$id_servico_}; ");
    while ($row06 = mysqli_fetch_assoc($consulta05)) {
        $observacao_texto = $row06['texto'];
    }

    $consulta06   = mysqli_query($conexao, "SELECT * FROM `observacao_servicos` WHERE `id_servico` = {$id_servico_}; ");
    while ($row07 = mysqli_fetch_assoc($consulta06)) {
        $data_3 = $row07['data'];
    }

    $gerando_status = mysqli_query($conexao, "SELECT * FROM `detalhes_servico` WHERE `id_servico` = {$id_servico_}");
    $contar_parcelas = mysqli_num_rows($gerando_status);
    while($row3 = mysqli_fetch_assoc($gerando_status)){
        $status = $row3['status'];
        if(($status == 0) or ($status == 3) or ($status == 2)){
            $nao_concluido += 1;
        }
    }

    // ---------------- STATUS ----------------- //

    if ($contar_parcelas == 1) {
        $busca_tipo_status = mysqli_query($conexao, "SELECT * FROM `detalhes_servico` WHERE `id_servico` = {$id_servico_} AND `tipo_servico` = 1");
        while ($row_busca_status = mysqli_fetch_assoc($busca_tipo_status)) {
            $status_final = $row_busca_status['status'];
        }
    }
    if ($contar_parcelas == 2) {
        $busca_tipo_status = mysqli_query($conexao, "SELECT * FROM `detalhes_servico` WHERE `id_servico` = {$id_servico_} AND `tipo_servico` = 2");
        while ($row_busca_status = mysqli_fetch_assoc($busca_tipo_status)) {
            $status_final = $row_busca_status['status'];
        }
    }
    if ($contar_parcelas == 3) {
        $busca_tipo_status = mysqli_query($conexao, "SELECT * FROM `detalhes_servico` WHERE `id_servico` = {$id_servico_} AND `tipo_servico` = 3");
        while ($row_busca_status = mysqli_fetch_assoc($busca_tipo_status)) {
            $status_final = $row_busca_status['status'];
        }
    }
    if($status_final ==0){

        $nome_do_status = "A Protocolar";

    }
    if($status_final ==1){

        $nome_do_status = "Concluído";

    }
    if($status_final ==2){

        $nome_do_status = "Protocolado";

    }
    if($status_final ==3){

        $nome_do_status = "Em Andamento";

    }
    if($status_final ==4){

        $nome_do_status = "Pendência Forma";

    }
    if($status_final ==5) {

        $nome_do_status = "Pendência Cliente";
        
    }
    if($status_final ==6) {

        $nome_do_status = "Rescindido";
    }

    // ---------------- STATUS ----------------- //


    echo "<tr>";
    echo "<td>".$row['id']."</td>";
    echo "<td>".$row['ordem_de_servico']."</td>";
    echo "<td>".$row['id_servico']."</td>";
    echo "<td>".$row['nome_servico']."</td>";
    echo "<td>".$nomedocliente."</td>";
    echo "<td>".$nome_filial."</td>";
    echo "<td>".date('d/m/Y', strtotime($row['prazo_entrega']))."</td>";
    echo "<td>".date('d/m/Y', strtotime($row['contratacao']))."</td>";
    echo "<td>".$row['solicitante']."</td>";
    echo "<td>".$coordenacao."</td>";
    echo "<td>".$tecnico."</td>";
    echo "<td>".$tecnico_interno."</td>";
    echo "<td>".number_format($row['valor'], 2, ',', '.')."</td>";
    echo "<td>".$row['parcela_comissao']."</td>";
    echo "<td>".$nome_do_status."</td>";
    echo "<td>".$observacao_texto."</td>";
    echo "<td>".date('d/m/y', strtotime($data_3))."</td>";
    echo "</tr>";
}

echo '</tbody>
            </table>
        
        ';

echo '
  <script src="assets/js/jquery.table2excel.js"></script>
  <script>
    $(function() {
      $(".table").table2excel({
        exclude: ".noExl",
        name: "Lista de Serviços",
        filename: "lista_servicos",
        fileext: ".xls",
        exclude_img: true,
        exclude_links: true,
        exclude_inputs: true
      });
    });
  </script> 
  ';


$insere_registro   = mysqli_query($conexao, "INSERT INTO `historico_acoes` (`id`, `nome_usuario`, `id_usuario`, `acao`, `ip`, `data`, `tipo`) VALUES (NULL, '{$usuario_nome}', {$usuario}, 'Exportou Relatório de serviços cadastrados', '{$ip}', '{$data_contratado}', 6);");


mysqli_close($conexao);

?>

Compartilhar este post


Link para o post
Compartilhar em outros sites

alan de souza arantes

Sua dúvida esta mais ou menos dentro da sua própria lógica.

O código esta meio bagunçado e sem você especificar quais os campos que estão vázios e quais os valores que ele assumi, se de outro campo ou se qualquer um outro valor, fica díficil lhe ajudar.

 

Mas fazendo uma breve analise o que eu encontrei de errado é o seguinte:

 

Você tem um LOOP WHILE PRINCIPAL e dentro dele você tem outros LOOP WHILE SECUNDÁRIOS, o que PODE acontecer é que você só alimenta a sua variável de saida SE você encontrar o resultado na sua tabela.

 

EXEMPLO:

TAB1               TAB2               TAB3

REG                 VALOR1          VALOR2

1                       1                      2

2                       1

3                                               1

 

Você fez o primeiro select na tabela 1

Resultado do LOOP PRINCIPAL / REG = 1

          ai você tem o LOOP 2 para obter o resultado da TAB2

          Valor1 obtido no segundo select = 1

          ai você tem o LOOP 3 para obter o resultado da TAB3

          Valor2 obtido no terceiro select = 2

VOLTOU para o primeiro LOOP / REG = 2

          ai você tem o LOOP 2 para obter o resultado da TAB2

          Valor1 obtido no segundo select = 1

          ai você tem o LOOP 3 para obter o resultado da TAB3

          no terceiro select não tem nada, MAS você não atribui um valor novo porque não entra no WHILE então o valor dele fica 2 que foi o valor encontrado anteriormente.

VOLTOU para o primeiro LOOP / REG = 3

          ai você tem o LOOP 2 para obter o resultado da TAB2

          no segundo select não tem nada, MAS você não atribui um valor novo porque não entra no WHILE então o valor dele fica 1 que foi o valor encontrando anteriormente.

          ai você tem de novo o 2 LOOP e para cada resultado você alimenta a variavel de novo

          Valor obtido no terceiro select = 1

FIM LOOP PRINCIPAL

...

Entendeu.

 

O que eu recomendo, ANTES de cada WHILE  você deve LIMPAR suas variáveis.

Ficando assim:

//OKAY AQUI

while ($row = mysqli_fetch_assoc($results)) {
    $id_cliente       = $row['id_cliente'];
    $id_servico_      = $row['id'];
    $id_filial        = $row['id_filial'];
    $id_coordenacao   = $row['coordenacao'];
    $id_tecnico       = $row['tecnico'];
    $id_tecnico_int   = $row['tecnico_interno'];
    $observacao       = $row['texto'];
    $data_3           = $row['data'];
//ATÉ AQUI

//ENTÂO VOCÊ TEM ESSE AQUI:

 

    $consulta   = mysqli_query($conexao, "SELECT * FROM `clientes` WHERE `id` = {$id_cliente}; ");
    while ($row01 = mysqli_fetch_assoc($consulta)) {

//ENTENDA QUE A VARIAVEL $nomedocliente SÓ SERA ALIMENTADA SE ENCONTRAR.
        $nomedocliente = $row01['nome_cliente'];
    }

 

//RECOMENDO VOCÊ SEMPRE LIMPAR ELA E DEPOIS VER SE ALIMENTA OU NÃO.

    $nomedocliente = ""; //LIMPO

    while ($row01 = mysqli_fetch_assoc($consulta)) {
        $nomedocliente = $row01['nome_cliente'];
    }

 

//OUTRO MEIO É, SE O SEU SELECT NÃO TE RETORNAR UMA LISTA (+ de 1 Registro).

//RECOMENDO VOCÊ USAR O IF NO LUGAR DO WHILE E NO ELSE LIMPAR

//A VARIAVEL CASO NÃO ENCONTRE NADA NA TABELA

//FICANDO ASSIM:

    if ($row01 = mysqli_fetch_assoc($consulta)) {
        $nomedocliente = $row01['nome_cliente']; //Alimenta com o valor da tabela
    } else {

        $nomedocliente = ""; //Não encontrou nada na tabela LIMPA a variavel

    }

 

Tenho certeza que com isso você ira resolver o seu problema.

Espero ter ajudado.

 

Att.
Felipe Coutinho

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, tudo bem?
       
      Tenho o seguinte codigo:
       
       class Data {
      public static function ExibirTempoDecorrido($date)
      {
          if(empty($date))
          {
              return "Informe a data";
          }
          $periodos = array("segundo", "minuto", "hora", "dia", "semana", "mês", "ano", "década");
          $duracao = array("60","60","24","7","4.35","12","10");
          $agora = time();
          $unix_data = strtotime($date);
          // check validity of date
          if(empty($unix_data))
          {  
              return "Bad date";
          }
          // is it future date or past date
          if($agora > $unix_data) 
          {  
              $diferenca     = $agora - $unix_data;
              $tempo         = "atrás";
          } 
          else 
          {
              $diferenca     = $unix_data - $agora;
              $tempo         = "agora";
          }
          for($j = 0; $diferenca >= $duracao[$j] && $j < count($duracao)-1; $j++) 
          {
              $diferenca /= $duracao[$j];
          }
          $diferenca = round($diferenca);
          if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
          return "$diferenca $periodos[$j] {$tempo}";
      }
      }
       
      Funciona redondinho se o valor retornado for de algumas horas, mas...
      Quando passa de dois meses, ele retorna a palavra mess. Deve ser por conta dessa linha
      if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
       
      Quero que modre:
       
      2 meses atrás
      e não
      2 mess atrás.
       
      Espero que tenham entendido.
       
      Valeu
    • Por Carlos Web Soluções Web
      Olá...
      Estou tentando fazer o seguinte !!
      Listando dados em tabela !!
      Gostaria que....se na listagem houver 4 linhas...indepedente de seu número de ID, faça a listagem em ID ser em ordem 1 2 3 4 !!
      Exemplo...se tiver uma listagem de dados que está em ID 1 3 3...faça ficar 1 2 3 !!

       
      echo "<table class='tabela_dados' border='1'> <tr> <td>ID</td> <td>Nome Empresa</td> <td>Responsável</td> <td>Telefone 1</td> <td>Telefone 2</td> <td>E-mail 1</td> <td>E-mail 2</td> <td>Endereço</td> <td>CEP</td> <td>Bairro</td> <td>AÇÃO 1</td> <td>AÇÃO 2</td> </tr> "; $sql = "SELECT ID FROM usuarios_dados WHERE Usuario='$usuario'"; $result = $conn->query($sql); $num_rows = $result->num_rows; $Novo_ID = 1; for ($i = 0; $i < $num_rows; $i++) { $registro = $result -> fetch_row(); $sql2 = "UPDATE usuarios_dados SET ID='$Novo_ID' WHERE ID='$Novo_ID'"; $result2 = $conn->query($sql2); $Novo_ID++; } $sql = "SELECT * FROM usuarios_dados"; $result = $conn->query($sql); if ($result->num_rows > 0) { // output data of each row while($row = $result->fetch_assoc()) { echo "<tr> <td>$row[ID]</td> <td>$row[Nome_Empresa]</td> <td>$row[Responsavel]</td> <td>$row[Telefone_1]</td> <td>$row[Telefone_2]</td> <td>$row[Email_1]</td> <td>$row[Email_2]</td> <td>$row[Endereço]</td> <td>$row[CEP]</td> <td>$row[Bairro]</td> <td> <form method='post' action='Editar_Dados.php'> <input type='hidden' name='usuario' value='$usuario'> <input type='hidden' name='senha' value='$senha'> <input type='hidden' name='ID' value='$row[ID]'> <input type='submit' style='padding: 10px;' value='EDITAR'> </form> </td> <td> <form method='post' action='Deletar_Dados.php'> <input type='hidden' name='usuario' value='$usuario'> <input type='hidden' name='senha' value='$senha'> <input type='hidden' name='ID' value='$row[ID]'> <input type='submit' style='padding: 10px;' value='DELETAR'> </form> </td> </tr> "; } } else { echo "0 results"; } $conn->close();  
    • Por ILR master
      Boa tarde pessoal, tudo bem ?
       
      Eu uso o tinymce para cadastro de textos no meu siite, porém, quero fazer um sistema para que os colunistas possam fazer o próprio post.
      O problema do tinymce, é que ele mantém a formatação do texto copiado, como tamanho de fonts, negritos, etc... Quero que o usuário cole o texto e a própria textarea limpe a formatação para que ele formate como quiser.
       
      A pergunta é:
       
      O tinymce tem uma opção para desabilitar a formatação quando um texto é colocado?
      Tem alguma função via java ou php para retirar a formatação assim que o texto é colado?
      Ou é melhor usar um outro editor?
       
      Agradeço deste já.
    • Por Giovanird
      Olá a todos!
      Tenho uma pagina que possui uma DIV onde coloquei uma pagina PHP.
      Uso a função setInterval para atualizar a pagina inclusa dentro da DIV.
      O problema é que ao acessar o site , a DIV só me mostra a pagina inclusa somente quando completo o primeiro minuto.
      Preciso que a pagina inclusa já inicie carregada
       
      Meu código JavaScript e a DIV com a pagina PHP
       
      <script> function atualiza(){ var url = 'direita.php'; $.get(url, function(dataReturn) { $('#direita').html(dataReturn); }); } setInterval("atualiza()",60000); </script> <div> <span id="direita"></span> </div>  
    • Por ILR master
      Fala pessoal.
       
      Seguinte:
       
      Quero selecionar duas tabelas e mostrar com resultados intercalados. Abaixo segue um código explicando para vcs terem uma ideia.
       
      $consulta = "SELECT A.*, B.* FROM tabela1 A, tabela2 B'";
      $resultado = mysqli_query($conexao, $consulta) or die ("erro");
      while($busca = mysqli_fetch_array($resultado)){
       
      print $busca['cod_evento']; --> traz o código da tabela1 
      print $busca['titulo_evento']; -->  traz o titulo da tabela1
      print $busca['cod_noticia']; --> traz o código da tabela2
      print $busca['titulo_noticia']; --> traz o tituloda tabela2
       
      }
       
      Espero que entendam. Grato
       
×

Informação importante

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