Jump to content
Willian Simione

Soma da Tabela KM com a Tabela abastecimento

Recommended Posts

Estou com duas tabelas onde  uma eu somo o km de cada carro, e outra que eu somo a quantidade de litragem abastcido, porem tem carro que não abastece na garagem e na hora d eeu mostrar  a media por carro abastecido ele acaba entrando no somatório e é onde da o erro Warning: Division by zero in, como faço pra fazer essa soma e excluir os carro que não estao com o abastecimento.Abaido deixo as tabelas

 

Esse soma o KM , todos os carro tem KM

 $soma4 = $conectar->query("SELECT SUM(tkm) AS total FROM cad_km where carro='$carro'");
   $count4 = $soma4->fetchColumn();

Esse soma a Litragem, porem o tem carro que não abastece, 

   $soma3 = $conectar->query("SELECT round(SUM(litros),0) AS total FROM cad_abastec where dtabastec BETWEEN '$data1' AND '$data2' and carro='$carro'");
   $count3 = $soma3->fetchColumn();
 

image.png.47f6a052da8e80e7a6a45ed4d976e7c7.png

 

Share this post


Link to post
Share on other sites

Talvez minha sugestão não seja das melhor, mais  para obter o resultado esperado você precisa fazer um JOIN entre as tabelas. Além disso, precisa usar funções de agregação com GROUP BY para conseguir agrupar e somar os valores.

Sua query ficaria assim:

 

Exemplo 1

 

<?php
SELECT a.nome, 
       COALESCE(SUM(b.media), 0) AS media
  FROM tabela_a a
  LEFT JOIN tabela_b b ON b.id_categoria = a.id
 GROUP BY a.nome;

 

Agora se você deseja calcular a média e não a soma, deverá usar a função AVG ao invés de SUM.

 

Exemplo 2

<
SELECT a.nome, 
       COALESCE(AVG(b.media), 0) AS media
  FROM tabela_a a
  LEFT JOIN tabela_b b ON b.id_categoria = a.id
 GROUP BY a.nome;

NO EXEMPLO DO COALESCE

Como não teremos informações sobre CARRO1 e CARRO2 na tabela B o resultado da aplicação de uma função de agregação para seus registros, seja a média (AVG) ou a soma (SUM), será nulo (NULL).

A função COALESCE permite que o NULL seja substituído por outro valor, 0 nos exemplos. Ela avalia todos os parâmetros informados e retorna sempre o primeiro diferente de nulo.

COALESCE(NULL, 1, 3) retorna o segundo parâmetro, o valor 1.

COALESCE(2, 1) retorna o primeiro parâmetro, o valor 2.

COALESCE(AVG(b.media), 0) retorna a média, se diferente de NULL, senão 0.

Neste caso específico também poderíamos utilizar a função IFNULL (que só aceita 2 parâmetros, enquanto COALESCE pode avaliar vários parâmetros) com o mesmo resultado do COALESCE.

 

 

Veja a Documentação

Documentação MySQL JOIN

Documentação MySQL GROUP BY

Documentação MySQL COALESCE

Documentação MySQL IFNULL

 

Caso este outro exemplo ajudar veja aqui

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 Caio Vargas
      Fala pessoal tudo bem
      Estou criando um site para o cliente e ele me pediu para colocar um tradutor ao clicar nas bandeiras
      porem eu nao queria fazer uma pagina para cada traduçao eu queria fazer tipo usando o google Translate 
       
      alguem tem alguma sugetao de como posso fazer ou um exemplo 
      grato
    • By Kelven
      Bom dia pessoal tudo bem?
      Então, estou trabalhando em um site em php e preciso usar a api do facebook para obter o feed do instagram, porém a chave token é um conteúdo muito sensível, então decidi fazer em php para ela não ficar disponível do lado do cliente. Alguém sabe me dizer se é possível fazer isso? Porque eu pesquisando no google só achei maneiras de fazer em javascript.
    • By gersonab
      Boa noite, tenho pesquisado porém não encontrei, então vamos lá.
      tenho uma lista de itens ( documentos ) cadastrados no banco de dados e os seus respectivos arquivos em uma pasta, se eu preciso de um deles clico e faço o download deste, no entanto como fazer para fazer o download de vários ao selecionar com checkbox os que eu quero ?
      desculpem por não postar nenhum código, mas é que não estou sabendo como fazer os downloads de vários.
      Qual o procedimento correto ?
       
    • By Mauricio Molina
      Bom dia.
       
      Estou precisando de um freelancer em PHP.
       
      Resolver um problema em um script de portal de noticias, onde a imagem não esta sendo upada, fica apenas em "em processamento".
       
      Contato: contato@weblina.com.br
       
      Obrigado!

    • By gersonab
      Boa tarde, preciso fazer uma busca por um ou mais itens, consigo fazer a busca pelo mês e ano, porém se eu quiser colocar tb a pessoa e mais uma condição não esta dando certo.
      <?php $mes=(int)$_POST['mes']; $ano=(int)$_POST['ano']; $idp=(int)$_POST['idp']; $pagoparc=$_POST['pagoparc']; $consulta1 = $pdo->query("SELECT parcelas.idpar, parcelas.procid, parcelas.procli, parcelas.proadv, parcelas.valorp,parcelas.valorpe, parcelas.valoradv, parcelas.valorpago, parcelas.datapar, parcelas.datapago, parcelas.pagoparc, parcelas.obspar, cli.idc, cli.nomec, proc.idpr, proc.proces, prof.idp, prof.nomep FROM parcelas LEFT JOIN cli ON cli.idc = parcelas.procli LEFT JOIN proc ON proc.idpr = parcelas.procid LEFT JOIN prof ON prof.idp = parcelas.proadv WHERE Month(parcelas.datapar) = $mes AND YEAR(parcelas.datapar) = $ano AND parcelas.proadv LIKE '%$idp%' AND parcelas.pagoparc LIKE '%$pagoparc%' ORDER BY parcelas.idpar ASC"); while ($user1 = $consulta1->fetch(PDO::FETCH_ASSOC)) { ?> desta forma retorna todos os resultados independente do mês  e ano
       
      <?php $mes=(int)$_POST['mes']; $ano=(int)$_POST['ano']; $idp=(int)$_POST['idp']; $pagoparc=$_POST['pagoparc']; $consulta1 = $pdo->query("SELECT parcelas.idpar, parcelas.procid, parcelas.procli, parcelas.proadv, parcelas.valorp,parcelas.valorpe, parcelas.valoradv, parcelas.valorpago, parcelas.datapar, parcelas.datapago, parcelas.pagoparc, parcelas.obspar, cli.idc, cli.nomec, proc.idpr, proc.proces, prof.idp, prof.nomep FROM parcelas LEFT JOIN cli ON cli.idc = parcelas.procli LEFT JOIN proc ON proc.idpr = parcelas.procid LEFT JOIN prof ON prof.idp = parcelas.proadv WHERE Month(parcelas.datapar) = $mes AND YEAR(parcelas.datapar) = $ano AND parcelas.proadv = $idp AND parcelas.pagoparc = $pagoparc ORDER BY parcelas.idpar ASC"); while ($user1 = $consulta1->fetch(PDO::FETCH_ASSOC)) { ?> já desta forma me retorna este erro :
      Fatal error: Call to a member function fetch() on a non-object in
       
      lembro que nesta busca posso ter ou não o idp e ou pagoparc
×

Important Information

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