Skip to content

Conversation

@rkistner
Copy link
Contributor

This keeps prepared statements around for the last table, to avoid preparing a new statement for every row that we insert/delete.

I did not fully confirm, but I expect that the way the query plan is structured that the rows would typically be processed one table at a time, making it efficient to only keep the tables for the last query. It is not an issue if the order is different - we may just lose a little of the performance benefits here.

In my tests on native desktop with an in-memory db, this reduced the overall sync_local duration by around 25% (2786ms -> 2075ms for 500k rows). When taking into account filesystem overhead, the impact will be a little less, but still significant.

@rkistner rkistner requested a review from simolus3 May 27, 2025 08:43
simolus3
simolus3 previously approved these changes May 27, 2025
Copy link
Contributor

@simolus3 simolus3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me 👍 I agree that we don't have to worry about enforcing table order here.

@rkistner rkistner force-pushed the reuse-prepared-statements branch from bd2acf0 to 42e3da1 Compare May 28, 2025 14:37
@rkistner rkistner changed the base branch from optimize-sync-local to main May 28, 2025 14:38
@rkistner rkistner dismissed simolus3’s stale review May 28, 2025 14:38

The base branch was changed.

@rkistner rkistner requested a review from simolus3 May 28, 2025 14:41
@simolus3 simolus3 merged commit a21580a into main May 28, 2025
21 checks passed
@simolus3 simolus3 mentioned this pull request Jun 11, 2025
10 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants