Jump to content
gabrielslessa

Soma PDO dentro do foreach php

Recommended Posts

Olá amigos, sou novato no PDO e estou quebrando cabeça para fazer uma consulta e somar os valores da coluna da tabela de itens com um parametro predefinido ('id' e 'pedido_min') onde id é o id do produto e pedido_min está no bd mysql como (ENUM) Y ou N, onde Y quer dizer que esse produto não entra na soma do pedido minimo da compra e N entra na soma do pedido minimo. Estou fazendo isso para que produtos como exemplo de cigarros não entrem na conta do pedido minimo. 

 

Tenho um FOREACH que lista os produtos que estao na SESSION php, dentro ou fora desse FOREACH eu preciso somar os produtos que possuem o parametro Y na coluna 'pedido_min' do bd, para diminuir da soma total  do carrinho de compras e checar se o cliente atingiu o valor minimo de compra (15,00), caso tenha atingido o valor minimo entao libera o botao para fechar o pedido.

 

meu código está abaixo:

 

<div class="card-body">
          
          <?php     
            
            //buscando no bd o valor do pedido minimo
            $config = app('db')->select("SELECT as_configura.* FROM as_configura");
			$config = $config[0];
				
                //montando cart dos produtos sa session
				$cart_box = '<ul class="cart-products-loaded">';
				$total = 0;
				$total_acresc = 0;
				
				foreach ($_SESSION["products"] as $product) : 
				
					$product_name = $product["product_name"]; 
					$product_price = $product["product_price"];
					$product_acresc = $product["product_acresc"];
					$id = $product["id"];
					$product_qty = $product["product_qty"];
					
                    //somando o subtotal de cada item do carrinho
					$subtotal = ($product_price * $product_qty);
  
                    //total de todos o s itens
					$total = ($total + $subtotal);
					                     
  
                // checa se tem itens que nao entram na soma do pedido minimo
                $result = app('db')->select("SELECT as_produtos.preco FROM as_produtos WHERE id = $id AND as_produtos.pedido_min = 'Y'");
				
				//soma o valor total dos itens que nao entram na soma do pedido minimo
				$total_cigarro = app('db')->query("SELECT SUM(preco) AS total FROM as_produtos WHERE pedido_min = 'Y' AND id = $id ")->fetchColumn();
				$checaCigarro = $total - $total_cigarro;
  
  
                //checa de atingiu o pedido minimo
		        if ($total < $config['ped_minimo']) {
					
					echo "O pedido mínimo é de R$ ".$config['ped_minimo'].",00";
					
				
				//se tem itens que nao entram na soma do pedido minimo e soma 
				} else if (count($result) >= 1) {
					
					if ($checaCigarro < $config['ped_minimo']) {
						
						
						  echo "Cigarros não entram na soma de R$ ".$config['ped_minimo'].",00 do pedido mínimo.";
					}
																							
      ?>
                
                 <!-- PRODUCT -->
                  
                     AQUI ENTRAM AS INFORMACOES DE CADA ITEM
                    
                    <!-- END PRODUCT -->
                    
                     
                   <?php endforeach; ?>
  
  

 

Share this post


Link to post
Share on other sites

Saudações, Gabriel

 

Você utilizar o código da seguinte forma.

<?php
   //Variável traz o Código do Cliente Logado
   $codClie = "$userClientes_clienteId";

   $sql_pegaAtivos = "SELECT pro.codProdClie, pro.produtoDescr, pro.apres_unid, pro.clientes_clienteId, cr.cotaRespId, 
                             cr.cotaRespQtde, cr.cotaRespVlrUnit, cr.codProdClie, cr.clientes_clienteId, cr.cotacaoItens_cotaItensId, 
                             cr.cotaRespStatus, cr.cotaNumero, cr.cotaRespCompra, cr.cotaPertence,
                             SUM(cr.cotaRespQtde * cr.cotaRespVlrUnit) as soma
                        FROM cotacaoResposta cr
                  INNER JOIN produto pro ON pro.codProdClie = cr.codProdClie
                       WHERE cr.cotaNumero = :cotaNumero
                         AND cr.cotaPertence = pro.clientes_clienteId
                         AND cr.clientes_clienteId = '$codigoClie'
                         AND cr.cotaRespCompra = '1'
                    GROUP BY cr.cotacaoItens_cotaItensId ";  

                    try{
                        $query_pegaAtivos = $conecta->prepare($sql_pegaAtivos);
                        $query_pegaAtivos->bindValue(':cotaNumero',$cotaNumero,PDO::PARAM_STR);
                        $query_pegaAtivos->execute();

                        $resultado_pegaAtivos = $query_pegaAtivos->fetchAll(PDO::FETCH_ASSOC);
                        $count_pegaAtivos = $query_pegaAtivos->rowCount(PDO::FETCH_ASSOC);

                        } catch(PDOexception $error_pegaAtivos) {
                          echo 'Erro ao pegar ativos';
                        }

                foreach($resultado_pegaAtivos as $resAtivos){              
                        $cotaRespId         = $resAtivos['cotaRespId'];     
                        $cotaRespQtde       = $resAtivos['cotaRespQtde'];     
                        $cotaRespVlrUnit    = $resAtivos['cotaRespVlrUnit'];
                        $cotaRespStatus     = $resAtivos['cotaRespStatus'];
                        $cotaRespCompra     = $resAtivos['cotaRespCompra'];
                        $cotaPertence       = $resAtivos['cotaPertence'];
                        $cotaNumero         = $resAtivos['cotaNumero'];
                        $codProdClie        = $resAtivos['codProdClie'];
                        $clientes_clienteId = $resAtivos['clientes_clienteId']; 
                        $valorQtvUn         = $resAtivos['soma']; //Está variável traz o resultado do (SUM(cr.cotaRespQtde * cr.cotaRespVlrUnit) as soma)
                        $produtoClie        = $resAtivos['codProdClie'];
                        $descrProd          = $resAtivos['produtoDescr'];
                        $apresProd          = $resAtivos['apres_unid'];

?>
                                                                    
       <div class="box-body" style="font-size:13px; line-height:0.5;">
            &bull;&nbsp;<?php echo $produtoClie;?> - <?php echo $descrProd;?> - 
            R$ <?php echo number_format($valorQtvUn,2,",",".");?>
       </div>

       <?php } ?><!--/. Fim do: Foreach Relação Produto X CotaçãoResposta-->
                                            
     
      <td align="right" width="15" height="10" style="font-weight:bold; color:#035803; font-size:16px; background:#E1FFF7;" >
          <?php echo number_format($totalQtvUn,2,",",".");?>
     </td>
     <td align="right" width="15" height="10" style="font-weight:bold; font-size:16px; background:#FEFFD1;" >
         <?php echo $faturaMinimo; ?>
    </td>  
    <?php if($vrFinal < '0') { ?>                                  
          <td align="right" width="15" height="10" style="font-weight:bold; color:#F70000; font-size:16px; background:#F3F7F6;">
              <?php echo number_format($vrFinal, 2, ",", "."); ?>
          </td> 
    <?php } else { ?>
          <td align="right" width="15" height="10" style="font-weight:bold; color:#010162; font-size:16px; background:#F3F7F6;">
              <?php echo number_format($vrFinal, 2, ",", "."); ?>
         </td>
                                       
    <?php } ?> 

 

 

Espero ter ajudado com o exemplo acima.

 

Cesar

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 Camilavip
      Boa noite a todos, estou tendo um probleminha em gravar a senha criptografada, na verdade editar, pois quando gravo vai certo, mas na edição não está dando certo.
      A baixo quando cadastro o cliente é assim, e está indo perfeito.
       
      $nome = $_POST['nome']; $email = $_POST['email']; $login = $_POST['login']; $senha = sha1($_POST['senha']); Mas na hora da edição como está um pouco diferente estou tentando colocar esse sha1 em todo lugar e não está dando
      nome='$_POST[nome]', email='$_POST[email]', login='$_POST[login]', senha='$_POST[senha]', Então no de cima no cadastro está ok, mas na edição não sei mais aonde coloco esse sha1 para dar certo ou é burrice minha mesmo,
    • By Wallcrawler
      Olá pessoal tudo bem? Estou tentando fazer a cópia de uma imagem que está disponível na web e salvar em uma pasta no meu projeto. Essa imagem está sob protocolo SSL mas navegador consegue acessá-la normalmente. Mas o meu script php é bloqueado, e não entendo o porquê.
       
      Segue o código que estou usando:
      <?php //error_reporting(E_ALL ^ E_DEPRECATED); //ini_set('display_errors', 1); //die('Script travado!'); $start = microtime(true); set_time_limit(0); function save_image($inPath,$outPath) { //Download images from remote server $in = fopen($inPath, 'rb'); $out = fopen($outPath, 'wb'); while ($chunk = fread($in,8192)) { fwrite($out, $chunk, 8192); } fclose($in); fclose($out); } include_once ($_SERVER['DOCUMENT_ROOT'] . '/grpi/include/classes/Rpi.class.php'); include_once ($_SERVER['DOCUMENT_ROOT'] . '/grpi/include/functions.class.php'); $func = new FuncoesAuxiliares(); $rpi = new Rpi(); if(!isset($_GET['num_processo'])) { $rows = $rpi->Consulta('select num_processo, classe, especificacao from processos order by num_processo ASC limit 1'); } else { $rows = $rpi->Consulta("select num_processo, classe, especificacao from processos where num_processo > '" . $_GET['num_processo'] . "' order by num_processo ASC limit 1"); } $registros = 0; $arrayInsert = array(); $qtd_caracteres_total = 14; foreach ($rows as $rs) { //$rs['num_processo'] $zeros = ''; $qtd_char_processo = strlen($rs['num_processo']); //Fill zeros for($i=0; $i < ($qtd_caracteres_total - $qtd_char_processo); $i++) { $zeros .= '0'; } echo('BR5' . $zeros . $rs['num_processo'] . '<br>'); $url = 'http://www.tmdn.org/tmview/trademark/image/BR5' . $zeros . $rs['num_processo']; //Aqui tento acessar a imagem e salvar na pasta correspondente save_image($url, __DIR__ .'/logo/' . $rs['num_processo'] . '.jpg'); //copy('https://www.tmdn.org/tmview/trademark/image/BR5' . $zeros . $rs['num_processo'], __DIR__ .'/logo/' . $rs['num_processo'] . '.jpg'); $processo = $rs['num_processo']; $registros++; } $registros = number_format($registros, 0, ',', '.'); // Display Script End time $time_end = microtime(true); //dividing with 60 will give the execution time in minutes other wise seconds $execution_time = ($time_end - $start)/60; //execution time of the script echo '<b>Total Execution Time:</b> '. $execution_time .' Mins <hr><br><br>Registros: ' . $registros . '<br><br>'; echo("<a href='down_logo.php?num_processo=" . $processo ."' target='_self'>Próxima página</a><br><br>"); ?> O erro retornado é o seguinte:
       
      Warning: fopen(): SSL: Connection reset by peer in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 10

      Warning: fopen(http://www.tmdn.org/tmview/trademark/image/BR500000825642590): failed to open stream: HTTP request failed! in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 10

      Warning: fread() expects parameter 1 to be resource, boolean given in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 12

      Warning: fclose() expects parameter 1 to be resource, boolean given in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 16
       
      Só que se você tentar acessar o endereço no browser, diretamente, a imagem aparece:
       
      https://www.tmdn.org/tmview/trademark/image/BR500000825642590 
       
      Onde posso estar errando? Obrigado pela atenção de todos.
    • By violin101
      Caros amigos,
       
      saudações...
       
      Estou escrevendo uma rotina de Carrinho de Compras e estou com problema na Library CART.
       
      Quando a Descrição do Produto ultrapassa 25 caracteres, o CART não é inserido.
       
      A library CART, estou chamando direto no AUTOLOAD.
       
      Como consigo resolver esse problema ?
       
      O Código para inserir está assim:
      <?php defined('BASEPATH') OR exit('No direct script access allowed'); class Carrinho extends CI_Controller { public function __construct() { parent::__construct(); $this->load->model('site/carrinho_model'); } public function index() { $this->addCart(); } public function addCart() { //Recebe dados via POST $id_produto = $this->input->post("idPrds"); $descricao = $this->input->post("namPrds"); //Problema nesse Campo quando ultrapassa 25 caracteres - Não INSERE $quantidade = $this->input->post("qtds"); $preco = $this->input->post("vlrPrds"); $insert_dados = array( 'id' => $id_produto, 'name' => $descricao, 'price' => $preco, 'qty' => $quantidade ); $this->cart->insert($insert_dados); $this->load->view('site/estilo/header', $this->data); $this->load->view('site/carrinho'); } }  
       
      Grato,
       
      Cesar
       
       
       
       
    • By Bruno Ferreira da Silva
      Estou utilizando laravel 5.8.
      Meu problema é o seguinte, estou realizando o login com usuário e senha. O sistema entra na condição e debuga corretamente o usuário logado. e no mesmo momento que eu altero a url para ..../dashboard, ele redireciona como se estivesse deslogando. mas na segunda tentativa isso não acontece, ele realiza o login normalmente. Ai isso se repete sempre que troca de usuário. 
       
      O controller da dashboard chama apenas a view e mais nada. 
      public function authenticate(Request $request) { $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { dd(Auth::user()); return redirect()->intended('dashboard'); } }  
    • By Sapinn
      Estou trazendo os dados do banco de dados e eles estão vindo com problema na acentuação
      uso o seguinte codigo no php
      <?php
      include_once ‘…/php/conexao.php’;
      header(‘Content-Type: text/html; charset=utf-8’);
      mysqli_query($conn,“SET NAMES ‘utf8’”);
      mysqli_query($conn,‘SET character_set_connection=utf8’);
      mysqli_query($conn,‘SET character_set_client=utf8’);
      mysqli_query($conn,‘SET character_set_results=utf8’);
      ?>
      E no html
      Mesmo assim as palavras com acento ficam com aquele erro desgraçado com a interrogação
      Alguem me ajuda ai
×

Important Information

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