QueryPlan

QueryPlan is what we call the ability to statically analyze a viewmodel to know ahead of time what data it will use.

QueryPlan is used to efficiently fetch the data for a view.

Since views may shift what data they show (seekers or when base nesting on variables) the QueryPlan logic is active even after view creation - to make sure the slow performing lazy fetch does not kick in.

Lazy fetch is a strategy to fetch the object needed for a object locator just in time. This is practical but if every object would fetch itself with a roundtrip to server the application would not scale at all.

QueryPlan has multiple steps:

  1. Statically figure out Hierarcy building expressions (the nestings). On this level we only collect Class and Relation + the classes that expressions used the allinstances operator on
  2. Statically figure out what the other columns use (the non nestings)

From these 2 steps we have static information about what TYPE of information that will - at one point or another - be used by the view - per hierarcy level

QueryPlan place subscription on all vCurrent variables for Nesting levels. Whenever a vCurrent variable is shifted it may be an opportunity for QueryPlan to efficiently fetch data below this point.

This happens for example is seekers - when user has a new list of objects - and the selected object may be root to show details. In this case QueryPlan will kick in and efficiently fetch such details for the selected object.

If your View is not a seeker in any form - the data is already fetched and QueryPlan should discover that no unseen objects are requested - and thus no fetch is needed

Understanding the Query planner

Static plan

Right click on the viewmodel main class and then select Extras and QueryPlan...

That will place a text block in the clip-board with report on what the QP tree seen.

QueryPlanStaticPlan.png
Viewmodel scope and expressions

See Analyze ViewModel classes and expressions for more information.

QP data in turnkey when debugging

At the end of the /debug page you can see the executed QP levels.

Keywords

Query optimizer, Query planner, optimise, view model optimiser

This page was edited more than 7 months ago on 05/27/2024. What links here