在存储过程中传递表的最佳方法是什么



>我正在尝试将表传递给存储过程以进行批量插入更新。我在数据库中为表创建了一个自定义类型,并使用表参数(自定义类型)创建了一个过程。

但是,当我在实体框架中更新模型时,它不会生成用于传递表参数的正确代码。

以下是我的存储过程的声明:

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是实体框架上下文,我可以通过它执行命令。

相关内容

最新更新