-
-
Notifications
You must be signed in to change notification settings - Fork 67
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
Added AppendStoredProcedureCall #1185
base: master
Are you sure you want to change the base?
Conversation
Sorry for late reply, I was busy with work. Can you maybe add some simple tests for calling insert/update/delete SPs, just to have basic validation that the SQL is correct. Something similar to what is in E2E tests. |
It looks like EXECUTE PROCEDURE SP_ABC p1, p2 will not work properly with EF concurrency checks. Will have to change it to SELECT * FROM SP_ABC(p1, p2, p3). |
AppendStoredProcedureCall fixed and tests added |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some minor pieces, otherwise LGTM in general.
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/DeleteTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/DeleteTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/DeleteTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/InsertTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/InsertTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/UpdateTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/UpdateTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/UpdateTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
src/FirebirdSql.EntityFrameworkCore.Firebird.Tests/EndToEndUsingSP/UpdateTestsUsingSP.cs
Outdated
Show resolved
Hide resolved
} | ||
} | ||
|
||
commandStringBuilder.Append("SELECT * FROM "); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would prefer here to be explicit about column names.
Explicit column names means that we cannot freely choose the results column names in SPs, but we can pick names for input parameters. Also, EFC uses result values by their positions and ignores any given result column names. |
Not sure why you added commit 53fccb6 , but that looks unrelated and needs to be removed. |
I don't follow. Can you elaborate? |
This reverts commit 53fccb6.
Not to use explicit names is how it's done in SQL Server implementation. If explicit column names are used, there would also be an issue with naming the column for the rows affected value. The name could be ROWSCOUNT, but it should be properly documented so developers writing stored procedures can easily find this information. |
SQL Server implementation uses
Yes. But same can be said about the whole SP structure. It needs to fit into what EF expects. |
Updated the code to use explicit column names. And i saw some additional issues with this AppendStoredProcedureCall code. When stored procedure doesn't have any return values defined SELECT * FROM SP() will produce an SQL error. In this case EXECUTE PROCEDURE should be used. Also AppendStoredProcedureCall code should probably throw some exceptions when output parameters or return values are defined. Made changes to fix these issues and added a test for case when ID isn't auto generetad and insert procedure doesn't return any values.
Hm, SQLServer stored procedures have 3 ways to return values including as selectable procedure.
Even if EF Core documentation is lacking, its possible to gues what EF is expecting from exceptions it throws. |
Added AppendStoredProcedureCall override to support InsertUsingStoredProcedure, UpdateUsingStoredProcedure, DeleteUsingStoredProcedure in model builder.