Solucionado (ver solução)
Solucionado
(ver solução)
1
resposta

[Dúvida] Ordenação em nível banco tem melhor desempenho?

Estava pensando, ao fazermos uma ordenação seja ela por nome, preço... Seria mais interessante (no caso do Java) criar um metódo no Repository do objeto passando nossa query de ordenação ou teria melhor desempenho com o 'sort' no parametro do controller?

1 resposta
solução!

Olá, Kauã

A sua pergunta é muito pertinente e é um tema que gera muitas discussões. De maneira geral, a ordenação no nível do banco de dados tende a ser mais eficiente. Isso ocorre porque os bancos de dados são projetados para lidar com grandes volumes de dados e têm algoritmos de ordenação otimizados para isso.

No seu caso, ao utilizar Java e provavelmente um framework ORM como Hibernate ou Spring Data, quando você utiliza o método 'sort' no parâmetro do controller, os dados são primeiro carregados na memória do aplicativo e depois ordenados. Isso pode ser menos eficiente, especialmente se você estiver lidando com grandes volumes de dados, pois pode consumir muita memória e CPU.

Por outro lado, se você passar a query de ordenação para o repositório, a ordenação será feita no nível do banco de dados. Isso significa que o banco de dados retornará os dados já ordenados, o que pode ser mais eficiente.

No entanto, é importante notar que a diferença de desempenho pode não ser perceptível se você estiver trabalhando com pequenos volumes de dados. Além disso, a ordenação no nível do aplicativo pode ser mais flexível, pois você pode ordenar os dados com base em critérios que não são facilmente expressos em uma query SQL.

Um exemplo prático seria:

// Ordenação no nível do banco de dados
@Repository
public interface ProdutoRepository extends JpaRepository<Produto, Long> {
    List<Produto> findAllByOrderByNomeAsc();
}

// Ordenação no nível do aplicativo
@GetMapping("/produtos")
public List<Produto> getProdutos(@RequestParam Optional<String> sort) {
    List<Produto> produtos = produtoRepository.findAll();
    if (sort.isPresent() && sort.get().equals("nome")) {
        produtos.sort(Comparator.comparing(Produto::getNome));
    }
    return produtos;
}

Espero ter ajudado e bons estudos!

Quer mergulhar em tecnologia e aprendizagem?

Receba a newsletter que o nosso CEO escreve pessoalmente, com insights do mercado de trabalho, ciência e desenvolvimento de software