-
-
Notifications
You must be signed in to change notification settings - Fork 307
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 our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Reverse engineering: relationship delete behaviour is incorrect #523
Comments
Not sure, but you should probably ask in the EF Core repo |
Reverse engineering will only use |
ClientSetNull means that EF (the client) will set any loaded foreign keys currently being tracked to null. But the database will continue to restrict (more or less the same thing as "no action") if you try to save the entity marked for delete. Having the client cascade the deletion into loaded entities can help make managing graphs of objects easier for scenarios like re-parenting. Also worth mentioning that SQL Server doesn't actually support RESTRICT, so EF always uses NO ACTION instead. See also dotnet/efcore#21252 (comment). I agree we need to review this area of the code. |
Not sure now where is best to comment, but one of your replies in the other thread is: “Given that the foreign keys and their delete behaviour is defined in the database, I fail to see how this makes much difference if any if scaffolding from an existing database.” I can give you a use case but it does feel like a simple point that the reverse engineering should just accurately model the database. I have built a system around checking dependencies before deleting an entity so that: With reverse engineering I would expect the modelled delete behaviour to match the database. If I desire some client behaviour such as ClientCascade, I can modify as such and the delete routine will load and audit them for deletion. In the given example (unfortunately one of many) the user will delete an Applicant, be given no warning about dependent ApplicationForms, then EF will throw an exception trying to set the FK to null. Because I have built a system on the assumption the metadata EF holds about the database is accurate, and where it isn’t it’s because I’ve manually modified it. But currently it’s not accurate off the bat. |
Closing as there is not really anything to do for Power Tools here. |
A non-nullable foreign key is reversed engineered into a relationship where the delete behaviour is ClientSetNull
Steps to reproduce
Applicant and ApplicationForm tables:
data:image/s3,"s3://crabby-images/59529/595293b62dcfc6f3de53e176e1dd646ff0e1de55" alt="image"
Reverse engineered into this:
ClientSetNull summary mentions:
This is the default for optional relationships. That is, for relationships that have nullable foreign keys.
Should it actually be Cascade, which says:
This is the default for required relationships. That is, for relationships that have non-nullable foreign keys.
Unless I'm missing something. Thanks
Further technical details
EF Core Power Tools version: Version 2.4.217.0
Database engine: SQL Server
Visual Studio version: 2019 16.7.2
The text was updated successfully, but these errors were encountered: