Ir para conteúdo

Arquivado

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

lendadomato

Agrupar dados via Ajax

Recommended Posts

Pessoal,
preciso agrupar dados de uma consulta, o que tenho retorna os dados que preciso mas
não consigo organizá-los dessa forma:

////////////////////////////////////////////////

2018(3) - R$ 480,00

 

-Fevereiro - (2) - R$ 240,00
 Gabriel - 20/02/2018
 Alberto - 19/02/2018
 
-Janeiro - (1) - R$ 240,00
 Alberto - 17/01/2018
 
 
2017(2) - R$ 240,00
-Dezembro - (1) - R$ 120,00
 Gabriel - 18/12/2017

-Novembro - (1) - R$ 120,00
 Gabriel - 18/11/2017
////////////////////////////////////////////////
 
Mas o que eu consegui foi dessa forma:
////////////////////////////////////////////////
2017(2) - R$ 240,00
2018(3) - R$ 480,00
 
Fevereiro - (2) - R$ 240,00
Janeiro - (1) - R$ 240,00
Dezembro - (1) - R$ 120,00
Novembro - (1) - R$ 120,00
 
Gabriel - 20/02/2018
Alberto - 19/02/2018
Alberto - 17/01/2018
Gabriel - 18/11/2017
Gabriel - 18/12/2017
////////////////////////////////////////////////
 
Segue abaixo as consulta do PHP, lembrando que o campo da data é do tipo varchar:
listar-vendas.php
$idusuario = $_POST['idusuario'];

$db->sql("SELECT *, RIGHT(datacad, 4) as ano, COUNT(*) AS totalAno, sum(totalcomp) AS somaAno FROM cad_compras WHERE idusuario = $idusuario AND nivel = 'Venda' GROUP BY RIGHT(datacad, 4) ORDER BY guidcomp DESC");
  $res =  $db->getResult();

  echo json_encode($res);

 

listar-vendas-mes.php

$idusuario = $_POST['idusuarioo'];
$ano = $_POST['ano'];

$db->sql("SELECT DISTINCT SUBSTRING(datacad, 3, 4) AS mes, COUNT(*) AS contagem, sum(totalcomp) AS total, guidcomp FROM cad_compras WHERE RIGHT(datacad, 4) = '$ano' AND idusuario = '$idusuario' AND nivel = 'Venda' GROUP BY mes ORDER BY mes DESC");
  $res =  $db->getResult();

  echo json_encode($res);

 

listar-vendas-vendas.php

$idusuario = $_POST['idusuariooo'];
$ano = $_POST['ano'];
$mes = $_POST['mes'];

$db->sql("SELECT * FROM cad_compras WHERE idusuario = '$idusuario' AND RIGHT(datacad, 4) = '$ano' AND SUBSTRING(datacad, 3, 4) = '$mes' ORDER BY datacad DESC");
  $res =  $db->getResult();

  echo json_encode($res);

 

Javascript

this.listarVendas = function(page, callback) {
    
var idgravadouser = localStorage.getItem('idusuario');
var listavend = $("#listaVendas");
fw7.showIndicator();
    $.ajax({
    url:  'model/Cadastros/Compras/listar-vendas.php',
    type: 'POST',
    data: 'idusuario='+idgravadouser,
    success: function(dados){
          
      var i = null;
      
      $.each(dados, function(index,dado){
        var ano        = dado.ano;
        var totalAno        = dado.totalAno;
        var somaAno        = 'R$ '+formataMoeda(dado.somaAno);

        i++;
        
        
    $.ajax({
    url:  'model/Cadastros/Compras/listar-vendas-mes.php',
    type: 'POST',
    data: 'idusuarioo='+idgravadouser+'&ano='+ano,
    success: function(dados){
        var j = null;
      
      $.each(dados, function(index,dado){
        var mes        = dado.mes;
        var contagem        = dado.contagem;
        var total        = 'R$ '+formataMoeda(dado.total); 
        
        if(mes == "/01/"){
            var mestext = "Janeiro";
        }else if(mes == "/02/"){
            var mestext = "Fevereiro";
        }else if(mes == "/03/"){
            var mestext = "Março";
        }else if(mes == "/04/"){
            var mestext = "Abril";
        }else if(mes == "/05/"){
            var mestext = "Maio";
        }else if(mes == "/06/"){
            var mestext = "Junho";
        }else if(mes == "/07/"){
            var mestext = "Julho";
        }else if(mes == "/08/"){
            var mestext = "Agosto";
        }else if(mes == "/09/"){
            var mestext = "Setembro";
        }else if(mes == "/10/"){
            var mestext = "Outubro";
        }else if(mes == "/11/"){
            var mestext = "Novembro";
        }else if(mes == "/12/"){
            var mestext = "Dezembro";
        }

        j++;
                $("#meSes").append(mestext+' - '+contagem+' - '+total+'<br>');
                
         $.ajax({
    url:  'model/Cadastros/Compras/listar-vendas-vendas.php',
    type: 'POST',
    data: 'idusuariooo='+idgravadouser+'&ano='+ano+'&mes='+mes,
    success: function(dados){
        var j = null;
      
      $.each(dados, function(j,obj){
        var nomeclientecomp        = obj.nomeclientecomp; 
        var datacad        = obj.datacad;
       
        j++;
                $("#liSta").append(nomeclientecomp+' - '+datacad+'<br>');
      });
            }
        });       
                
                
                
      });
            }
        });
        
        
 $("#aNos").append(ano+'('+totalAno+') - '+somaAno+'<br>');       
        
        
        
}); 



  }
});
fw7.hideIndicator();   

};

 

Eu tenho essa aplicação em PHP que funciona mas queria passar para ajax porque todos os dados precisarão
ser atualizados ao editar/excluir.

Alguém alguma solução de como posso trazer esses dados organizados/agrupados?
Desde já agradeço a ajuda.

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

você primeiro tem que resolver isso no lado do servidor.
Lá no SQL.


Estude sobre JOIN.

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 hora atrás, William Bruno disse:

você primeiro tem que resolver isso no lado do servidor.
Lá no SQL.


Estude sobre JOIN.

Pelo que vi sobre JOIN, ele serve para consulta em duas tabelas diferentes, no meu caso
os dados estão em apenas uma tabela, consegui fazer com PHP no link abaixo mas eu
preciso desse retorno em ajax. A consulta do mês depende dos anos listados no loop e a
consulta dos dados precisa do resultado da consulta por mês agrupados. O vendedor precisa
listar as vendas por data que é do tipo Varchar:

Link em PHP

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pessoal,
eu consegui colocar os meses relacionados embaixo do ano respectivos assim:

2018(4) - R$ 480,00
Fevereiro - 3 - R$ 360,00
Janeiro - 1 - R$ 120,00

2017(2) - R$ 360,00
Dezembro - 1 - R$ 120,00
Novembro - 1 - R$ 240,00

 

Agora não consigo colocar os clientes relacionados embaixo dos meses, a consulta sql continua a mesma
e o ajax que foi alterado dessa forma:

this.listarVendas = function(page, callback) {
    
var idgravadouser = localStorage.getItem('idusuario');
var listavend = $("#listaVendas");
fw7.showIndicator();
    $.ajax({
    url:  'model/Cadastros/Compras/listar-vendas.php',
    type: 'POST',
    data: 'idusuario='+idgravadouser,
    success: function(dados){
          
      var i = null;
      
      $.each(dados, function(index,dado){
        var ano        = dado.ano;
        var totalAno        = dado.totalAno;
        var somaAno        = 'R$ '+formataMoeda(dado.somaAno);

        i++;
        
        
    $.ajax({
    url:  'model/Cadastros/Compras/listar-vendas-mes.php',
    type: 'POST',
    data: 'idusuarioo='+idgravadouser+'&ano='+ano,
    success: function(dados){
        var j = null;
        var meses = '';
      
      $.each(dados, function(index,dado){
        var mes        = dado.mes;
        var contagem        = dado.contagem;
        var total        = 'R$ '+formataMoeda(dado.total); 
        
        if(mes == "/01/"){
            var mestext = "Janeiro";
        }else if(mes == "/02/"){
            var mestext = "Fevereiro";
        }else if(mes == "/03/"){
            var mestext = "Março";
        }else if(mes == "/04/"){
            var mestext = "Abril";
        }else if(mes == "/05/"){
            var mestext = "Maio";
        }else if(mes == "/06/"){
            var mestext = "Junho";
        }else if(mes == "/07/"){
            var mestext = "Julho";
        }else if(mes == "/08/"){
            var mestext = "Agosto";
        }else if(mes == "/09/"){
            var mestext = "Setembro";
        }else if(mes == "/10/"){
            var mestext = "Outubro";
        }else if(mes == "/11/"){
            var mestext = "Novembro";
        }else if(mes == "/12/"){
            var mestext = "Dezembro";
        }

        j++;
        
  
        meses += mestext+' - '+contagem+' - '+total+'<br>';
           
      });
      
 $("#aNos").append(ano+'('+totalAno+') - '+somaAno+'<br>'+meses+'<br>'); 
 
            }
        });
        
        
}); 



  }
});
fw7.hideIndicator();   

};

 

Aqui o ajax que mostra os clientes:

$.ajax({
    url:  'model/Cadastros/Compras/listar-vendas-vendas.php',
    type: 'POST',
    data: 'idusuariooo='+idgravadouser+'&ano='+ano+'&mes='+mes,
    success: function(dados){
        var j = null;
        var clientes = '';
      
      $.each(dados, function(j,obj){
        var nomeclientecomp        = obj.nomeclientecomp; 
        var datacad        = obj.datacad;
       
        j++;
        clientes += nomeclientecomp+' - '+datacad+'<br>';
        
      });
            }
        });

 

html

<div id="aNos"></div>

Se alguém souber como colocar os clientes relacionados com seus respectivos meses
eu fico muito grato.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • 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.