Jump to content
TheRonaldoStar

Gostaria de tirar uma dúvida referente a uma consulta ao banco de dados!

Recommended Posts

Olá. eu gostaria de tirar uma dúvida que já faz exatamente 1 dia que eu estou fazendo pesquisas e nada.

Minha dúvida é a seguinte, Estou fazendo um aplicativo de mensagem por browser se e que pode se chamar assim.

Tipo eu tenho o loby de mensagem semelhante ao Whatsapp e quando a pessoa clica em conversas eu faço a consulta via ajax

Nesta consulta eu só informo o meu id ou seja o id do usuário logado. e na pagina php eu faço a seguinte consulta no banco de dados:

Procurar por todas as mensagens da tabela: privado, Nesta consulta me retorna todas as mensagens cujo meu id existe como na coluna: Para, com o status da mensagem valor 0

Ou seja 0= Disponível e 1 seria deletada. este e o código usado:

 

$sql = $db->prepare("SELECT * FROM privado WHERE Para = '$ID_user' AND Status = '0' ORDER BY id DESC");

$sql->execute();

 

Continuando;

Após o fazer esta consulta coloquei para listar tudo com o while, colocando todos os id dos usuários em uma variável e dentro deste mesmo while eu faço

Outra consulta por os usuários informado pela variável id da pessoa que mandou. e isso ocorre com sucesso, ou seja eu consigo fazer quase tudo que eu quero.

Procurei pelas mensagem, pesquisei por estes usuários mostro: Nome, foto, e a mensagem; Este e o código usado:

 

while($dados = $sql->fetch(PDO::FETCH_OBJ)){
        $ID_De = ($dados -> De);
        $U_mensagem = ($dados -> Texto);

        $sql1 = $db->prepare("SELECT * FROM usuarios WHERE id = '$ID_De' ORDER BY id DESC");
        $sql1->execute();
        
        while($dados1 = $sql1->fetch(PDO::FETCH_OBJ)){
            $Foto = ($dados1 -> foto == "") ? "defaut.png" : $dados1 -> foto;
            $Nome = ($dados1 -> nome);
            echo "Nome: ".$Nome."<br>Foto: ".$Foto."<br>Mensagem: ".$U_mensagem."<br><br>";
        }
    }

 

No final fica tudo assim:

 

Nome: Moderador
Foto: user_3.png
Mensagem: Mensagem do moderador

Nome: Ronaldo
Foto: user_1.png
Mensagem: Como vai você?

Nome: Ronaldo
Foto: user_1.png
Mensagem: Olá

 

Mas no final das contas eu gostaria de saber somente uma coisa para que meu projeto funcione como quero:

Eu quero que a listagem da ultima mensagem de cada usuário não todas as mensagem daquele usuário, ou seja somente da ultima mensagem de cada um usuário

 

"Tabela nome: usuários

Colunas: [ id, De, Para, Texto, Status ]" 

 

Este e o código completo da pagina:

 

<?php
    $Hostname = "localhost";
    $Database = "servidor_app";
    $Charset = "utf8";
    $Username = "root";
    $Password = "";

    $db = new PDO('mysql:host='.$Hostname.';dbname='.$Database.';charset='.$Charset.'', $Username, $Password);
    $db -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
    $URL_ATUAL= "https://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
    parse_str(parse_url($URL_ATUAL, PHP_URL_QUERY), $vamos_ver);
    $ID_user = $vamos_ver['id'];

    $sql = $db->prepare("SELECT * FROM privado WHERE Para = '$ID_user' AND Status = '0' ORDER BY id DESC");
    $sql->execute();

    while($dados = $sql->fetch(PDO::FETCH_OBJ)){
        $ID_De = ($dados -> De);
        $U_mensagem = ($dados -> Texto);

        $sql1 = $db->prepare("SELECT * FROM usuarios WHERE id = '$ID_De' ORDER BY id DESC");
        $sql1->execute();

        while($dados1 = $sql1->fetch(PDO::FETCH_OBJ)){
            $Foto = ($dados1 -> foto == "") ? "defaut.png" : $dados1 -> foto;
            $Nome = ($dados1 -> nome);
            echo "Nome: ".$Nome."<br>Foto: ".$Foto."<br>Mensagem: ".$U_mensagem."<br><br>";
        }
    }
?>

 

Pro favor preciso de ajuda urgente.

Atenciosamente,

~Ronaldo

Share this post


Link to post
Share on other sites
22 horas atrás, TheRonaldoStar disse:

Eu quero que a listagem da ultima mensagem de cada usuário não todas as mensagem daquele usuário, ou seja somente da ultima mensagem de cada um usuário

Nesse caso você terá que ter uma coluna na tabela para armazenar a data e a hora da última postagem, daí é só fazer a comparação com a data e a hora atual mais atual, só exibindo esse resultado.

 

Só uma coisa queria ressaltar aqui:

Você está lançando consultas dentro de loop, isso sobrecarrega demais e você perderá em performasse.

O ideal é você fazer as consultas separadamente armazenar os valores daí manipular esses resultados.

Há algum tempo me deparei com essa situação similar veja:

https://forum.imasters.com.br/topic/580417-separar-resultados-com-base-de-outra-tabela/

 

Share this post


Link to post
Share on other sites
5 horas atrás, Omar~ disse:

Nesse caso você terá que ter uma coluna na tabela para armazenar a data e a hora da última postagem, daí é só fazer a comparação com a data e a hora atual mais atual, só exibindo esse resultado.

 

Só uma coisa queria ressaltar aqui:

Você está lançando consultas dentro de loop, isso sobrecarrega demais e você perderá em performasse.

O ideal é você fazer as consultas separadamente armazenar os valores daí manipular esses resultados.

Há algum tempo me deparei com essa situação similar veja:

https://forum.imasters.com.br/topic/580417-separar-resultados-com-base-de-outra-tabela/

 

 

Poderia dar um exemplo com código por favor ?, estou confuso. ahh e a coluna hora já armazena o horário.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Guilherme Scarpatto
      Estou fazendo um website de perguntas e respostas, na qual o usuário adiciona sua pergunta e outros usuários podem respondê-las, basicamente como esse. Eu consegui fazer até a parte que o usuário cadastra a pergunta no banco, agora eu empaquei na parte de mostrar esssas perguntas na tela inicial do site para que outros usuários possam respondê-las. Queria uma ajuda de como posso fazer isso, qualquer coisa posso postar os cógidos aqui depois.
    • By cleriston.melo
      Olá pessoal,
       
      Estou com a seguinte dúvida:
      Preciso impimir as informações de um array criado a partir de uma consulta ao banco de dados, mas preciso imprimir essas informações "quebrada".
      Ex: Nas informações contidas no array, tem cod_exp, controle, serie, cod_prod e quant_prod.
      Eu preciso imprimir as informações por serie.tipo:
       
      Série: 1
      (cod_prod)                     quant_prod
      Produto 1                          10
      Produto 2                          30
      Produto 3                          20
      Produto 4                          50
      ---------------
      Série: 2
      (cod_prod)                     quant_prod
      Produto 1                          10
      Produto 2                          30
      Produto 3                          20
      Produto 4                          50
      ---------------
      etc...
      ----------------------------------------
      O código é esse:
       
      <?php
                      $query_prod_exp = "select * from estoque_expositor where est_exp_cod_exp=$cod_exp and est_exp_ativo='S' order by est_exp_cod_exp";
                      $result_prod_exp = mysqli_query($con, $query_prod_exp) or die(mysqli_error());
                      $row_prod_exp = mysqli_fetch_array($result_prod_exp);
                      
                      $controle = $row_prod_exp['est_exp_controle'];
                      $serie = $row_prod_exp['est_exp_controle'];
                      $cod_prod = $row_prod_exp['est_exp_cod_prod'];
                      $saldo_atual = $row_prod_exp['est_exp_quant_prod'];
                      
                          // ESCREVE UMA LINHA NA TABELA
                          echo "<tr>";
                      
                          // ESCREVE UMA COLUNA NA TABELA E EXIBE O NOME DO PRODUTO
                          echo "<td>";
                          $query_prod = "select * from produtos where prod_id=$cod_prod";
                          $result_prod = mysqli_query($con, $query_prod) or die(mysqli_error());
                          while ($row_prod = mysqli_fetch_array($result_prod)) {
                              $prod = $row_prod['prod_nome'];
                              echo $prod."</td>";
                          }
                          echo "<td>" . $saldo_atual . "</td>";
                          echo "</tr>";
                  ?>
       
      Obrigado a todos pela ajuda...
    • By rohilario_
      Galera, boa tarde!
      Estou desenvolvendo um sistema com PHP, Mysql, JS e Bootstrap, que gerencia sorteios conforme cadastro.
      Tudo funcionando perfeitamente, contudo atualmente fazemos impressões em um layout e colocamos em uma urna, na qual acontece o sorteio manual..
      Gostaria, de alguma forma, criar uma tela de sorteio, onde ele buscaria as informações do banco (coluna cartela) e sorteasse um número de cartela qualquer com alguns efeitos de "suspense".
       
      O grande problema para mim até o momento: Fraco em JS apesar de fazer algumas "coisinhas"; Não faço ideia nem por onde começar, comecei tão somente lendo alguns efeitos com jquery.
      https://api.jquery.com/category/effects/
      Não sei como pegar as informações do banco mysql com JS.
      Sugeri o JS por conta das libs disponíveis, mas poderia ser com o proprio PHP...
       
      Agradeço as colaborações desde já!
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.