Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

[release/9.0-staging] Fix to #35239 - EF9: SaveChanges() is significantly slower in .NET9 vs. .NET8 when using .ToJson() Mapping vs. PostgreSQL Legacy POCO mapping#35360

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to ourterms of service andprivacy statement. We’ll occasionally send you account related emails.

Already on GitHub?Sign in to your account

Merged
maumar merged 2 commits intorelease/9.0-stagingfromfix35239_90
Jan 6, 2025

Conversation

@maumar
Copy link
Contributor

@maumarmaumar commentedDec 19, 2024
edited
Loading

Fixes#35239
Safer version of#35326

Description

EF9 introduced a change in how we construct ValueComparers for some of our types (specifically collection of scalars/references), in preparation for AOT work. The way the change was implemented may cause a severe performance regression during SaveChanges operation involving multiple entities using collections of primitives (one of our highly requested features).

Customer impact

Customers performing data manipulation operations on entities with collections of primitives may experience significant performance regressions. This may also happen when no data has been changed, but sufficiently large entity graph has been loaded into change tracker. There is no workaround for this issue, apart from changing the model to not use primitive collections (which is unacceptable for majority of customers)

How found

Multiple customer reports on EF 9

Regression

Yes, from EF8. Note: this is a perf regression only, not a functional regression.

Testing

Ad hoc performance test using BenchmarkDotNet. Functional testing already covered by existing tests.

Risk

Low. The patch fix has been limited in scope to reduce the risk. Changes should only affect models with primitive collections. Added quirks just to be sure.

Perf numbers

Over 20x regression between 8 and 9 for the tested scenario.

8.0.11

MethodMeanErrorStdDev
SaveChangesTest172.1 ms1.78 ms1.58 ms

9.0

MethodMeanErrorStdDev
SaveChangesTest5.487 s0.0621 s0.0551 s

9.0.2 (with fix)

MethodMeanErrorStdDev
SaveChangesTest179.8 ms1.71 ms1.43 ms

@maumarmaumar changed the titleFix to #35239 - EF9: SaveChanges() is significantly slower in .NET9 vs. .NET8 when using .ToJson() Mapping vs. PostgreSQL Legacy POCO mapping[release/9.0-staging] Fix to #35239 - EF9: SaveChanges() is significantly slower in .NET9 vs. .NET8 when using .ToJson() Mapping vs. PostgreSQL Legacy POCO mappingDec 19, 2024
…s. .NET8 when using .ToJson() Mapping vs. PostgreSQL Legacy POCO mapping
@maumarmaumar marked this pull request as ready for reviewDecember 20, 2024 23:04
@maumar
Copy link
ContributorAuthor

@AndriySvyryd update: added changes to the cosmos StringDictionaryComparer. It does support nested collections and the legacy functions can be invoked (rather than just being constructed like in relational). I added targeted fix similar to what I initially did for main.

@AndriySvyryd
Copy link
Member

Looks good. Can you add the servicing template?

maumar reacted with thumbs up emoji

@maumarmaumar added this to the9.0.x milestoneDec 31, 2024
@maumar
Copy link
ContributorAuthor

/azp run

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@maumarmaumar merged commit2954996 intorelease/9.0-stagingJan 6, 2025
7 checks passed
@maumarmaumar deleted the fix35239_90 branchJanuary 6, 2025 10:30
This was referencedNov 24, 2025
Sign up for freeto join this conversation on GitHub. Already have an account?Sign in to comment

Reviewers

@AndriySvyrydAndriySvyrydAndriySvyryd approved these changes

Assignees

No one assigned

Projects

None yet

Milestone

9.0.2

Development

Successfully merging this pull request may close these issues.

3 participants

@maumar@AndriySvyryd

[8]ページ先頭

©2009-2025 Movatter.jp