LIMIT e OFFSET no Oracle


Outra coisa pentelha no Oracle, fazer paginação de registros. Não, o Oracle não tem as cláusulas LIMIT e OFFSET. Elas são utilizadas no PostgreSQL e no MySQL. O padrão SQL 2008 estabelece o uso do OFFSET e FETCH, utilizado pelo DB2, MS SQL Server e também pelo PostgreSQL. Já o Oracle… bom o Oracle só permite usar o velho rownum, que infelizmente não obedece o ORDER BY, então você é obrigado a criar uma subconsulta para paginar dados.

Vamos ver 2 métodos aqui. O primeiro é o definido pelo mago do Oracle, o Tom Kyte, do Ask Tom:

SELECT * FROM (
  SELECT a.*, ROWNUM rnum FROM (
    SELECT * FROM tabela_enorme ORDER BY campo_indexado
  ) a WHERE ROWNUM <= 61200
) WHERE rnum >= 61000;
...
...
...
Decorrido: 00:00:31.39

Agora outro método utilizando algo que eu realmente adoro, Window Functions:

SELECT * FROM (
  SELECT row_number() OVER (ORDER BY campo_indexado) linha, p.* FROM tabela_enorme
) WHERE linha BETWEEN 91000 AND 91200;
...
...
...
Decorrido: 00:00:29.34

Ou seja, utilizando Window Functions você tem uma sintaxe mais elegante e compacta e ainda ganha no desempenho. Para variar, a solução mais simples é a melhor.

Claro… eu ainda espero que alguém na Oracle tenha o bom senso de implementar o LIMIT e OFFSET, assim como uma infinidade de outras coisas que tornam a vida do desenvolvedor mais simples.

Compartilhe

Você pode gostar

pg_hba.conf

Introdução O arquivo pg_hba.conf (PostgreSQL Host-Based Authentication) é uma peça fundamental na configuração de segurança de qualquer instância PostgreSQL. Ele define as regras de autenticação

Tuning de SO (no Linux)

Introdução Tuning refere-se ao processo de ajustar e otimizar o desempenho de um sistema, software ou aplicação. A otimização do sistema operacional é uma etapa

plugins premium WordPress