Dont expand formulas
What is in this MR
An important refactor for the formula language to update fields in the correct order instead of expanding every referenced formula in every field.
In a table with a text field A
, a formula F1
referencing A
and a formula F2
referencing F1
, before this refactor we were replacing every reference of F1
with the corresponding formula. This had the advantage of updating a row in a single update statement where all the formulas can use the non-formula field types.
In a table with numerous formula fields that reference other formulas though, we found that this method generates a large ANTLR tree and results in a sluggish SQL query. As a result, the simple cases are easy and efficient, while the complex cases are too slow to be practical.
This MR contains the logic to utilize the field dependencies table for determining the correct order to update the formula fields. This involves splitting the update into multiple statements to update the intermediate results first and the final formula last. By doing so, we can issue smaller and faster update statements without expanding intermediate formulas.
How to test this MR
-
Create a complex scenario:
- Create a table with number and single selects fields.
- Create multiple formulas comparing the single select field with different values and performing different calculations based on the comparison's result.
- Create other formula fields, using previous formulas and making additional comparisons/calculations.
- Do it again and again
-
Or ask @_dvd to share a test workspace
-
start the backend in production mode with:
BASEROW_BACKEND_DEBUG=off DJANGO_SETTINGS_MODULE=baserow.config.settings.base ./docker/docker-entrypoint.sh gunicorn-wsgi
-
Notice the difference when:
- opening the table
- creating a new row
- updating a cell
- updating a field
-
Verify everything in the formula language still works the same as before, just faster
-
Please ensure that the previous formulas are still functioning as they did before. When you save them again, they will no longer expand referenced formulas and will start using the intermediate result instead. Note that older formulas that have not been resaved might be slower now than before because the inner formula is still the expanded one so it could still be updated in a single UPDATE statement instead of multiple ones in the right order. However, if everything works as expected, we could consider creating a formula migration in the future to re-save every formula to start using the new logic.
Merge Request Checklist
-
changelog.md has been updated if required. -
New/updated Premium/Enterprise features are separated correctly in the premium or enterprise folder -
The latest Chrome and Firefox have been used to test any new frontend features -
Documentation has been updated -
Quality Standards are met -
Performance: tables are still fast with 100k+ rows, 100+ field tables -
The redoc API pages have been updated for any REST API changes -
Our custom API docs are updated for changes to endpoints accessed via api tokens -
The UI/UX has been updated following UI Style Guide
Closes #2757 (closed)
Merge request reports
Activity
assigned to @_dvd
added 21 commits
-
bfac44f7...3405844f - 18 commits from branch
develop
- a1a9ad2c - Don't expand inner formulas
- d11f14a3 - disable silk
- 096e8aa4 - wip
Toggle commit list-
bfac44f7...3405844f - 18 commits from branch
added 105 commits
-
988f1e99...2331ba27 - 102 commits from branch
develop
- 10c51977 - Don't expand inner formulas
- 8d9f734b - topological sort
- 5fe77efd - Fix tests; polish code
Toggle commit list-
988f1e99...2331ba27 - 102 commits from branch
added 30 commits
-
3289c479...6722d46a - 26 commits from branch
develop
- 07e0f6f0 - Don't expand inner formulas
- 80fbc689 - topological sort
- 3b09bced - Fix tests; polish code
- 1cbfc2ee - Add test to ensure the number of queries with nested formulas
Toggle commit list-
3289c479...6722d46a - 26 commits from branch
added 1 commit
- 4c144b75 - Add test to ensure the number of queries with nested formulas
added 1 commit
- 15d7f0b8 - Add test to ensure the number of queries with nested formulas
added 1 commit
- 14ff3532 - Add test to ensure the number of queries with nested formulas
marked the checklist item changelog.md has as completed
added MRready for review ⭐ label
requested review from @stribny
added MRreviewing 🔍 label and removed MRready for review ⭐ label
- Resolved by Petr Stribny
- Resolved by Petr Stribny