How to Optimizing Pagination with Multiple Joins on Large Datasets (10 Million Rows)

How to Optimizing Pagination with Multiple Joins on Large Datasets (10 Million Rows)

raihanozaraihanoza Posts: 3Questions: 1Answers: 0

Hello everyone,

I am currently working on a project where I need to paginate a very large dataset with around 10 million rows. I have implemented pagination using a CTE (Common Table Expression), and it performs well without significant delays, especially when compared to using the traditional FETCH method in SQL Server. However, I am encountering performance issues when combining the pagination with multiple JOIN operations, particularly with temporary tables. The query becomes significantly slower as more joins are added.

Here is a quick summary of the scenario:

  • Dataset with 10 million rows.
  • Using a CTE for pagination, which is performing well.
  • The issue arises when I introduce several JOIN operations, especially with temporary tables.

I am looking for recommendations on more optimal ways to handle this situation. Specifically, I would like to know if there are any strategies or query optimizations I could use to improve the performance of pagination when dealing with large datasets and multiple joins.

Any insights or suggestions would be greatly appreciated!

Thank you in advance for your help!

Answers

  • rf1234rf1234 Posts: 3,028Questions: 88Answers: 422

    First of all I would try to use views and put the complex joins inside those views. That could already give you a significant improvement.

    Then look at the indexing of your database tables. Do you have indexes on the columns you are joining? If the bottleneck is reading and not inserting or updating I'd rather add more indexes and give that a try, too.

  • raihanozaraihanoza Posts: 3Questions: 1Answers: 0

    I've added indexes to the columns, for the initial start page, it's fast, but when the page is deep, it's slow and need long time.

  • rf1234rf1234 Posts: 3,028Questions: 88Answers: 422

    Have you tried server side processing?

    https://datatables.net/reference/option/serverSide

  • raihanozaraihanoza Posts: 3Questions: 1Answers: 0

    Yes, what I'm doing right now is server side processing, my problem is in the query or something like that, is there a solution?

  • rf1234rf1234 Posts: 3,028Questions: 88Answers: 422

    First of all I would try to use views and put the complex joins inside those views. That could already give you a significant improvement.

    Have you tried this?

  • allanallan Posts: 63,831Questions: 1Answers: 10,518 Site admin

    I'd suggest taking the query that your server-side processing script is generating (there should be three queries in most cases) and run them manually with EXPLAIN ANALYZE to see what is taking the time in the query planner. That might give you an indication of where things can be optimised.

    Allan

Sign In or Register to comment.