EntityFrameworkExtras в Github изглежда обещаващо.
От сайта на Git hub:
DbContext context = new DbContext("ConnectionString");
var proc = new AddMemberStoredWithAddressesProcedure()
{
FirstName = "Michael",
LastName = "Bovis",
Age = 26,
Addresses = new List<Address>()
{
new Address() {Line1 = "16", Line2 = "The Lane", Postcode = "MA24WE"}
}
};
context.Database.ExecuteStoredProcedure(proc);
Където „AddMemberStoredWithAddressesProcedure“ и „Address“ са дефинирани със специални атрибути.
Имах възможност да го пробвам..
CREATE TYPE [dbo].[UdtGuidList] AS TABLE(
[Guid] [uniqueidentifier] NULL
)
GO
CREATE PROCEDURE [dbo].[MyUdtSproc]
-- Add the parameters for the stored procedure here
(@GuidList UdtGuidList READONLY)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
SELECT *
from Blog b
INNER JOIN @GuidList gl ON gl.Guid = b.BlogGuid
--where b.BlogGuid in (SELECT gl.Guid from @GuidList gl)
END
Той създаде този динамичен SQL с 5 реда от потребителски тип..
declare @p3 dbo.UdtGuidList
insert into @p3 values(N'333f3916-c823-e311-84f2-0022198ef787')
insert into @p3 values(N'33327a17-c34e-e211-9a8c-0022198ef787')
insert into @p3 values(N'333ebc24-c44e-e211-9a8c-0022198ef787')
insert into @p3 values(N'3338d557-c44e-e211-9a8c-0022198ef787')
insert into @p3 values(N'333d7f92-c44e-e211-9a8c-0022198ef787')
exec sp_executesql N'EXEC [dbo].[MyUdtSproc] @GuidList = @GuidList ',N'@GuidList [UdtGuidList] READONLY',@GuidList=@p3
Това може да свърши работата, но sql може да стане голям с много редове в дефинираната от потребителя таблица. Ще сравня това със стария ADO.
Опитах стария DataTable ADO (по-долу) и проследих SQL, за да видя какво произвежда. Беше ТОЧНО същото!
var dt = new DataTable();
dt.Columns.Add("Guid");
foreach (var r in list)
{
var row = dt.NewRow();
row["Guid"] = r.Guid;
dt.Rows.Add(row);
}
using (var conn = new SqlConnection(@"Server=AComputer\DEVSQL;Database=Booyaa;Trusted_Connection=True"))
{
using (var sproc = new SqlCommand("[dbo].[MyUdtSproc]", conn))
{
var param = new SqlParameter("@GuidList", SqlDbType.Structured);
param.TypeName = "[dbo].[UdtGuidList]";
param.SqlValue = dt;
sproc.Parameters.Add(param);
if (conn.State != ConnectionState.Open) conn.Open();
var reader = sproc.ExecuteReader();
}
}
Готино! Казвам, че тази библиотека е валидна опция.
Актуализация:
Повече информация от моя блог
Примерен проект на Visual Studio
person
TheDev6
schedule
14.01.2014