Shubham Sidnale
How AsNoTracking() impact on performance ?
  • Which condition we use & which not.
  • Impact on the application performance.
By Shubham Sidnale in .NET on Jan 07 2025
  • Ali Abo Ouf
    Jan, 2025 9

    **AsNoTracking()** is a method used to improve read-only query performance by disabling change tracking on the returned entities,**EF** by-default tracks changes that made to entities retrieved from database , allows it to detect any change to those entities and apply changes to db by **SaveChange()** method So by using **AsNoTracking()** EF skips tracking process which make the query more efficient for read only operations so the effects on performance are:1. Increased Query Performance :Improves read performance by reducing memory usage and CPU overhead , works well for read-only scenarios like displaying data 2.Reduce memory usage : EF doesn't store the status of the Entities that are not tracked in change tracker3.Faster Query Execution Since there is no need to track changes, EF skips the process of snapshotting the data and monitoring changes, resulting in faster queries.**Use AsNoTracking() when:**1. You are only reading data and not modifying it.2.Performance is critical.3.The result will not be saved back to the database. **Avoid AsNoTracking() when:**1. You need to modify the data and save changes.2. You require relationship fix-ups (automatically setting navigation properties).

    • 0


Most Popular Job Functions


MOST LIKED QUESTIONS