PHP Básico

Como fazer uma paginação no PHP e Mysql

Como montar uma paginação no  PHP e Mysql, paginando os resultados de uma consulta realizada no banco de dados Mysql utilizando um script de paginação simples, incluso no Post.

O exemplo a seguir poder ser utilizado em consultas realizados em outros bancos (ex: postgresql), basta você substituir as funções relacionadas ao Mysql pela às utilizadas no banco o qual você está utilizando.

Crie um arquivo “produto.php” com o seguinte código.

1º parte – consultando a quantidade total de registros na tabela.

$sql = "SELECT count(id) FROM produto ";

$result = $con->query($sql);
   
$return = $result->fetch_row();   
    
$rec_count = $return[0];

2º parte – consultando os registro e exibindo a listagem

Repare que iremos utilizar a variável GET “página” para controlarmos a exibição das páginas.

Ex: dominio.com.br?pagina=2

if( isset($_GET{'pagina'} ) ) {
 $page = $_GET{'pagina'} - 1;
 $offset = $rec_limit * $page ;
 }else {
 $page = 0;
 $offset = 0;
 }

 
$sql = "SELECT * FROM produto  $busca LIMIT $offset, $rec_limit";

$result = $con->query($sql);

if ($result->num_rows > 0) {

 while($row = $result->fetch_assoc()) {
 
?>

<div class="produto">  
 <p><?php echo $row['nome'] ?></p>
 <p><?php echo $row['preco'] ?></p>
</div>

<?php
 }
 }

3º – exibindo a paginação

Além de montar a lista com as páginas/links, exibimos também a quantidade de registros e a página atual.

<p>Qtd. total de registros: <?php echo $rec_count  ?></p><br/>

<p>Pagina atual: <?php echo  isset($_GET['pagina']) ? $_GET['pagina'] : "1"  ?></p><br/>

<p>Paginas: </p>   
<?php 

 $qtd_paginas = (int) ($rec_count /   $rec_limit) ;
    
 $qtd_paginas  = ( ($qtd_paginas %   $rec_limit ) > 0 ) ? $qtd_paginas  + 1 : $qtd_paginas;
  
 for($i = 1; $i <= $qtd_paginas; $i++ ){
 ?>     
 <a href="produto.php?pagina=<?php echo $i ?>"><?php echo $i ?></a>
 <?php
   
 }

?>

Conclusão da paginação no PHP e Mysql

No exemplo foi utilizado a tabela “produtos” com as colunas “id, nome e preço”, altere de acordo com a sua necessidade.

É importante que você faça a revisão do código, buscando realizar otimizações e adequações de acordo com o seu sistema e versão do PHP utilizada.

Script completo:

<?php

$sql = "SELECT count(id) FROM produto ";

$result = $con->query($sql);
   
$return = $result->fetch_row();   
    
$rec_count = $return[0];

if( isset($_GET{'pagina'} ) ) {
 $page = $_GET{'pagina'} - 1;
 $offset = $rec_limit * $page ;
}else {
 $page = 0;
 $offset = 0;
}

 
$sql = "SELECT * FROM produto  $busca LIMIT $offset, $rec_limit";

$result = $con->query($sql);

if ($result->num_rows > 0) {

 while($row = $result->fetch_assoc()) {
 
?>

<div class="produto">  
 <p><?php echo $row['nome'] ?></p>
 <p><?php echo $row['preco'] ?></p>
</div>

<?php
 }
 } 
 ?>
 
 <p>Qtd. total de registros: <?php echo $rec_count  ?></p><br/>

<p>Pagina atual: <?php echo  isset($_GET['pagina']) ? $_GET['pagina'] : "1"  ?></p><br/>

<p>Paginas: </p>   
<?php 

 $qtd_paginas = (int) ($rec_count /   $rec_limit) ;
    
 $qtd_paginas  = ( ($qtd_paginas %   $rec_limit ) > 0 ) ? $qtd_paginas  + 1 : $qtd_paginas;  
  
 for($i = 1; $i <= $qtd_paginas; $i++ ){
 ?>     
   <a href="produto.php?pagina=<?php echo $i ?>"><?php echo $i ?></a>
 <?php
   
 }

?>

 

 

 

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás