Jump to content
Guest

Relacionamento de tabelas

Recommended Posts

Guest

É possível relacionar 4 tabelas onde uma delas não apresenta registros, e mesmo assim listar de uma tabela base?

 

tabela_pontos  (4 registros) (tabela base onde irão ser listados os registros)

usuario (4 registros)

agenda (4 registro)

historico (0 registros)

 

é possível relacioná-las caso o histórico esteja sem registros? Pois até agora não consegui resolver este probleminha rsrs.

Share this post


Link to post
Share on other sites

Como está a sua query? Em tese se você juntar com um left join, você terá os registros correlatos mesmo que uma das tabelas estejam em branco.

Share this post


Link to post
Share on other sites
Guest
3 horas atrás, ESerra disse:

Como está a sua query? Em tese se você juntar com um left join, você terá os registros correlatos mesmo que uma das tabelas estejam em branco.

<?php
    $id_user = 1; //vende um REQUEST (GET OU POST)
    $p = "`tabela_pontos`";
    $u = "`usuario`";
    $a = "`agenda`";
    $h = "`historico`";
    //para simplificar coloquei as colunas em all (*)
    $selecao = "" .
            "SELECT
                $p.*, $u.*, $a.*, $h.*       
            FROM
                $a  

            INNER JOIN $u ON ($u.`id` = $a.`id_user`)

            INNER JOIN $p ON ($p.`id_user` = $u.`id`) 
                
            INNER JOIN $h ON ($h.`id_user` = $u.`id`) 

            WHERE 
                    $a.`id_user` = '{$id_user}'
                        
                AND 
                    ($a.`pontos` > 0 AND $p.`pontos` >= $a.`pontos`)
                AND
                    ($h.`status`= '0' AND $h.`tipo`='1')

            ORDER BY 
                $a.`pontos`
                
            DESC, RAND()
            
            LIMIT
                5";

 

Share this post


Link to post
Share on other sites
Guest

Na verdade acho que isso se aplicaria numa condicionalidade, pois a minha intensão é não mostrar registros que já estejam no histórico.

Por exemplo:

Tenho 4 registros na "tabela_1", caso 1 deles exista na tabela "historico" não exibi-lo, os outros 3 se mostrarão.

O problema é que se não existirem registros no histórico, não mostra nada.

Share this post


Link to post
Share on other sites

Não sei se entendi bem a questão, mas creio que uma subquery no seu select deve ajudar.

SELECT
                $p.*, $u.*, $a.*, $h.*       
            FROM
                $a  

            INNER JOIN $u ON ($u.`id` = $a.`id_user`)

            INNER JOIN $p ON ($p.`id_user` = $u.`id`) 
                

            WHERE 
                    $a.`id_user` = '{$id_user}'
                        
                AND 
                    ($a.`pontos` > 0 AND $p.`pontos` >= $a.`pontos`)
                AND
                    ($h.`status`= '0' AND $h.`tipo`='1')
				AND
                    $u.`id` NOT IN 
						(SELECT $h.id_user FROM $h)

            ORDER BY 
                $a.`pontos`
                
            DESC, RAND()
            
            LIMIT
                5

Veja se é isso mesmo que você precisa

 

Qualquer coisa é só avisar.

Share this post


Link to post
Share on other sites
20 minutos atrás, android17 disse:

RodriAndreotti só não te dou um beijo na boca por que sou hétero... mais fico lhe devendo favores rsrs...

Resolvido o problema!

 

Kkkkk

Dispenso o beijo também... kkkk :sweat_smile:

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 violin101
      Caros amigos
       
      saudações...
       
      Primeiramente peço desculpa se postei minha dúvida na opção errada.
       
      Estou escrevendo uma Rotina para Impressão de Relatório usando mPDF, até aqui tudo bem.
       
      O relatório tem um: Título - Tabela - Dados.
       
      Minha dúvida:
      --[ como faço para REPETIR em todo SALTO de Página o Título ou Cabeçalho da Tabela, por exemplo:
       
      Título.................: Relatório de Estoque
      Tabela Campos: Código | Descrição | ESP | Qtde | Valor
       
      Grato,
       
      Cesar 
       
    • By Sapinn
      Opa galera tudo beleza? Então meu banco está me retomando um erro quando tento inserir nele que é "Dados truncados na coluna valor_produto" essa coluna era do tipo Double quando eu mudei para ela para TEXT funcionou os dados foram inseridos mas eu preciso que ela seja do tipo double. Alguém sabe como resolver????
    • By k9studio
      Olá Amigos,
      se alguem puder dar um help fico muito grato
      seguinte:
      estou criando um sistema de login com cookie
      todas as paginas fica no patch
      www/htdocs/script/
      quando logar no dominio.com.br liberar o acesso no  cliente.dominio.com.br tambem
      acesso:dominio.com.br
      ou
      quando logar no cliente.dominio.com.br liberar o acesso no dominio.com.br tambem
      acesso:cliente.dominio.com.br
      e guando deslogar quebrar conxao com os dois
      existe uma maneira de fazer isso?
       
    • By Kefatif
      Prezados boa tarde.
       
      Preciso bloquear a edição de um date input de forma que só seja possível selecionar a data através do calendário.
       
      Alguém pode me ajudar?
       
      Utilizo php, html e js.
       
      <input type="date" value="<?php echo $data ?>" name="datacoleta" class="form-control" required style="width:100%;">  
      Agradeço desde já.
×

Important Information

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