Boa tarde. Preciso de ajuda. Temos uma lista de produtos criada a partir de um select. O problema é que quando a página é carregada, me parece que ela faz a query no BD automaticamente e como não há ainda uma escolha (id) ele retorna erro. Segue: Notice: Undefined index: id in C:\Bitnami\wampstack-5.6.19-0\apache2\htdocs\casamento\escolha-produtos.php on line 128 $id = $_GET["id"];
Warning: mysqli_fetch_assoc() expects parameter 1 to be mysqli_result, boolean given in C:\Bitnami\wampstack-5.6.19-0\apache2\htdocs\casamento\banco-produto.php on line 104 while($array = mysqli_fetch_assoc($resultado)) {
Gostaria de que quando a página seja carregada, esse erro não aparecesse. Quando seleciono a categoria, ele traz o resutado sem problemas o problema aparece no carregamento da página Obrigado.
seguem os códigos:
pagina escolha-produtos que é carregada:
<?php
$id = $_GET["id"];
$produtos = listaProdutosporCategoria($conexao, $id);
?>
<table class="table table-striped table-bordered">
<?php foreach($produtos as $produto) : ?>
<div class="section ">
<div class="container container-border">
<div class="title">
<h4>Escolha os Produtos que Deseja Ganhar</h4>
</div>
<div class="row">
<div class="col-md-3">
<div class="card card-product card-plain">
<div class="image">
<a href="#">
<img width="90px" height="90px" width="auto" height="auto" img src="../cadastro/fotos/<?=$produto->getFoto() ?>" alt="Sem Imagem"/>
</a>
</div>
<div class="content">
<a href="#">
<h4 class="title"><?=$produto->getNome() ?></h4>
</a>
<p class="description">
<?= substr($produto->getDescricao(), 0, 40) ?>
</p>
<div class="footer">
<span class="price">R$ <?=$produto->getPreco() ?></span>
<button class="btn btn-danger btn-simple btn-hover pull-right" rel="tooltip" title="" data-placement="left" data-original-title="Adicionar a lista">
<i class="fa fa-heart-o"></i>
</button>
</div>
</div>
</div> <!-- end card -->
</div>
</div>
banco-produto na função listaProdutoporCategoria
function listaProdutosporCategoria($conexao,$id){
$retorno = 0;
$produtos = array();
$resultado = mysqli_query($conexao, "select p.*, c.nome as categoria_nome,
m.nome as marca_nome
from produtos p
inner join categorias c on(p.categoria_id = c.id)
inner join marcas m on(p.marca_id = m.id)
where c.id = {$id}");
while($array = mysqli_fetch_assoc($resultado)) {
$produto = new Produto();
$produto->setId($array['id']);
$produto->setNome($array['nome']);
$produto->setPreco($array['preco']);
$produto->setReferencia($array['referencia']);
$produto->setDescricao($array['descricao']);
$produto->setMarca(new Marca());
$produto->getMarca()->setId($array['marca_id']);
$produto->getmarca()->setNome($array['marca_nome']);
$produto->setCategoria(new Categoria());
$produto->getCategoria()->setId($array['categoria_id']);
$produto->getCategoria()->setNome($array['categoria_nome']);
$produto->carregaCaminhoFoto($array['foto']);
array_push($produtos, $produto);
}
return $produtos;
}