-
-
Notifications
You must be signed in to change notification settings - Fork 241
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improving pagination performance #870
Comments
This is working in production fairly well. protected function compileTableExpression($sql, $constraint, $query)
{
if ($query->limit == 1 && is_null($query->offset)) {
return "select * from ({$sql}) where rownum {$constraint}";
}
// Apply ROW_NUMBER() for pagination
$orderBy = $this->compileOrders($query, $query->orders);
// If no ORDER BY is specified, use ROWID for ordering
if (empty($orderBy)) {
$orderBy = "order by ROWID";
}
return "select * from (
select t1.*, row_number() over ({$orderBy}) as row_num
from ({$sql}) t1
) where row_num {$constraint}";
} Example query generated, down from 20s to 650ms: select * from (
select t1.*, row_number() over (order by ROWID) as row_num
from (select * from "INV"."ITM" where "ITM_CD" is not null and "DROP_DT" is null) t1
) where row_num between 126 and 150 Implemented in AppServiceProvider like so: class_alias (App\Database\Query\Grammars\OracleGrammar::class, \Yajra\Oci8\Query\Grammars\OracleGrammar::class); |
@alexc-jeromes thank you for taking your time in reviewing this issue. Can you please submit a PR, I will review it asap. |
Welcome! We literally just override this function. It would be worth testing this out though before a PR, as although it works for us, it may encounter other scenarios where it doesn't (i don't know the full scope of the package). PR submitted: #878 |
Just FYI, I tried implementing @alexc-jeromes override in our app, and it was great for a slow query issue we were having, but unfortunately we got errors in other queries, specifically ones with subqueries. For instance, we got ORA-01445 in a few places. I'm doing a lot of research, and I'm wondering if modifying |
@mixaster Yeh i suspected that might be the case. We're using it with quite simple queries and the solution is only needed for record browsing without complexity, so it will need a bit of tweaking. I can see the PR failed too. I'm not heavy enough into OCI8 to know the best way to do Oracle-specific driver work. We're moving to PG thankfully. |
This issue is stale because it has been open for 30 days with no activity. |
Pagination is insanely slow.
This code:
and produces:
then takes 23 seconds in PHP or Oracle in our DB of 500k records.
Change to
ROW_NUMBER() OVER
and it takes 0.8s.
GPT4 suggests:
The text was updated successfully, but these errors were encountered: