Changes between Version 2 and Version 3 of Ticket #35947, comment 3


Ignore:
Timestamp:
Nov 27, 2024, 4:04:17 PM (6 weeks ago)
Author:
Simon Charette

Legend:

Unmodified
Added
Removed
Modified
  • Ticket #35947, comment 3

    v2 v3  
    1515Which is one for the top-level houses queryset, two for the `rooms__windows` prefetch, and three for the `stories__rooms__windows` prefetch where two are duplicates. As explained above, invasive changes would be required to take that number to 4 under circumstances that your specific schema design seems to be exhibiting because of how you denormalized `Room.house` (already available through `Room.story.house`) and `Window.story` (already available through `Window.room.story`).
    1616
    17 If your application is executing 50x the number of 6 queries that could be reduced to 4 by implementing this optimization there is likely something else to look on your side before implementing this optimization. In other words `prefetch_related` is not a feature that systemically make elevated number of queries issues go away; it's a tool that bounds the N+1 query problem and not an identity mapper strategy #17.
     17If your application is executing 50x the number of 6 queries that could be reduced to 4 by implementing this optimization there is likely something else to look on your side before implementing this optimization. In other words `prefetch_related` is not a feature that systemically make elevated number of queries issues go away; it's a tool that bounds the N+1 query problem and not an identity mapper strategy #17 to accommodate your database denomalization needs.
Back to Top