C
C#•2mo ago
Krishna

What is the better way to identify who is the exact culprit in this exception?

Root Cause: Database Column and Entity Property mismatch (Nullable in Db and NotNULL in C# Entity). Message: Data is Null. This method or property cannot be called on Null values. StackTrace:
at Microsoft.Data.SqlClient.SqlBuffer.get_Boolean() at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.ShaperProcessingExpressionVisitor.<PopulateSplitCollectionAsync>d__31`3.MoveNext() at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.ShaperProcessingExpressionVisitor.<TaskAwaiter>d__36.MoveNext() at Microsoft.EntityFrameworkCore.Query.Internal.SplitQueryingEnumerable`1.AsyncEnumerator.<MoveNextAsync>d__21.MoveNext() at System.Runtime.CompilerServices.ConfiguredValueTaskAwaitable`1.ConfiguredValueTaskAwaiter.GetResult() at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.<SingleOrDefaultAsync>d__15`1.MoveNext() at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.<SingleOrDefaultAsync>d__15`1.MoveNext() at PoliEze.Portal.Application.Policies.Queries.GetPolicyFileMappingsQueryHandler.<Handle>d__4.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Policies\Queries\GetPolicyFileMappingsQuery.cs:line 25 at PoliEze.Portal.Application.Common.Behaviours.ValidationBehaviour`2.<Handle>d__2.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Common\Behaviours\ValidationBehaviour.cs:line 32 at PoliEze.Portal.Application.Common.Behaviours.UnhandledExceptionBehaviour`2.<Handle>d__2.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Common\Behaviours\UnhandledExceptionBehaviour.cs:line 18
at Microsoft.Data.SqlClient.SqlBuffer.get_Boolean() at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.ShaperProcessingExpressionVisitor.<PopulateSplitCollectionAsync>d__31`3.MoveNext() at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.ShaperProcessingExpressionVisitor.<TaskAwaiter>d__36.MoveNext() at Microsoft.EntityFrameworkCore.Query.Internal.SplitQueryingEnumerable`1.AsyncEnumerator.<MoveNextAsync>d__21.MoveNext() at System.Runtime.CompilerServices.ConfiguredValueTaskAwaitable`1.ConfiguredValueTaskAwaiter.GetResult() at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.<SingleOrDefaultAsync>d__15`1.MoveNext() at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.<SingleOrDefaultAsync>d__15`1.MoveNext() at PoliEze.Portal.Application.Policies.Queries.GetPolicyFileMappingsQueryHandler.<Handle>d__4.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Policies\Queries\GetPolicyFileMappingsQuery.cs:line 25 at PoliEze.Portal.Application.Common.Behaviours.ValidationBehaviour`2.<Handle>d__2.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Common\Behaviours\ValidationBehaviour.cs:line 32 at PoliEze.Portal.Application.Common.Behaviours.UnhandledExceptionBehaviour`2.<Handle>d__2.MoveNext() in D:\_PowerTeam\WDAC\_Repo\polieze\code\Portal\PoliEze.Portal.Application\Common\Behaviours\UnhandledExceptionBehaviour.cs:line 18
I want to know Can we figure out which is the exact column for which type or nullability has not matched?
6 Replies
Unknown User
Unknown User•2mo ago
Message Not Public
Sign In & Join Server To View
Krishna
KrishnaOP•2mo ago
I can go down and debug it, But I wanted to know, is there a better way to either identify or avoid such blunders. I can create an utility that can do some checking between my database tables and entities in the C# or I have another solution as well where I can create a code generator that can generate entities using database tables. There can be plenty of options, I wanted to open up this conversation to understand what is the right way.
Unknown User
Unknown User•2mo ago
Message Not Public
Sign In & Join Server To View
becquerel
becquerel•2mo ago
GitHub
GitHub - Giorgi/EntityFramework.Exceptions: Strongly typed exceptio...
Strongly typed exceptions for Entity Framework Core. Supports SQLServer, PostgreSQL, SQLite, Oracle and MySql. - Giorgi/EntityFramework.Exceptions
becquerel
becquerel•2mo ago
i don't know if it will give you the exact info you want for null entries into columns, etc., but this package is probably of interest to you you could also switch on more detailed logging from ef core to see what sql it tried to execute before the exception i don't know if there's a good way to catch these kinds of errors at compile-type in c#. there is some promising stuff in rust (like diesel), but i think that is mainly possible because of rust's more advanced type system and macro capabilities i sure wish there was a good way to do this, it would have saved me a lot of time and broken builds 🙂
Krishna
KrishnaOP•2mo ago
Thank you I will look into it..

Did you find this page helpful?