Skip to content

Reuse shapers across queries #34445

Open
Open

Description

We currently produce a shaper for each query we compile; since as many queries end up having identical shapers, we can have a cache which allows queries to reuse shapers. This would help reduce binary size for NativeAOT, and would also help regular JIT application performance as ew need to compile less shapers at runtime.

This is basically about figuring out the correct, comprehensive cache key for shapers, and implementing the caching.

Note that we also have #32923, which is about reusing materializers across queries (with materializers being the narrower piece of code that materializes an instance from DbDataReader, and therefore doesn't care about tracking/no-tracking, split query....). Both caches can be done independently.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions