>我正在尝试将表传递给存储过程以进行批量插入更新。我在数据库中为表创建了一个自定义类型,并使用表参数(自定义类型)创建了一个过程。
但是,当我在实体框架中更新模型时,它不会生成用于传递表参数的正确代码。
以下是我的存储过程的声明:
CREATE PROCEDURE [dbo].[TimeClock_UpdateTimeClockData]
@dateTimeFrom date,
@dateTimeTo date,
@employeeEarnings EmployeeEarningsTable readonly
AS
BEGIN
--- insert/update operations
END
这是实体框架生成的代码:
public virtual int TimeClock_UpdateTimeClockData(Nullable<System.DateTime> dateTimeFrom, Nullable<System.DateTime> dateTimeTo)
{
var dateTimeFromParameter = dateTimeFrom.HasValue ?
new SqlParameter("dateTimeFrom", dateTimeFrom) :
new SqlParameter("dateTimeFrom", typeof(System.DateTime));
var dateTimeToParameter = dateTimeTo.HasValue ?
new SqlParameter("dateTimeTo", dateTimeTo) :
new SqlParameter("dateTimeTo", typeof(System.DateTime));
return ((IObjectContextAdapter)this).ObjectContext.ExecuteStoreQuery("TimeClock_UpdateTimeClockData @dateTimeFrom,@dateTimeTo", dateTimeFromParameter, dateTimeToParameter);
}
它只是忽略表值参数。
实体框架是否有任何解决方法将表传递给过程?
或者是否有任何替代方法将多个记录传递给存储过程?我知道 Xml 参数,但我想避免这种情况,因为我想传递更大的数据集并且不想引起任何性能问题。
实体框架 deos 不会生成用于使用 table 参数调用存储过程的代码。但是,我找到了一种方法从上下文变量调用 sp 并传递表参数,如下所示:
var parameter = new SqlParameter("EmployeeEarnings", datatableEarnings);
parameter.TypeName = "dbo.UDT_EmployeeEarnings";
_context.Database.ExecuteSqlCommand("TimeClock_UpdateTimeClockData @EmployeeEarnings", parameter);
如果未为参数定义类型名称,则会引发错误。因此,通过声明一个新的 SqlParameter,然后分配 TypeName 属性可以解决此问题。
_context
是实体框架上下文,我可以通过它执行命令。