繁体   English   中英

使用ASP.NET MVC和Entity Framework将通用列表传递给存储过程

[英]Pass generic list to stored procedure using ASP.NET MVC and Entity Framework

SqlParameter param = new SqlParameter();
param.ParameterName = "@myList";
param.SqlDbType = SqlDbType.Structured;
param.Value = datatable;
param.Direction = ParameterDirection.Input;
param.TypeName = "tblTempBaseFileInsert";

var outPutList = db.Database.SqlQuery<int>("spInsertToBaseFile @myList", param).FirstOrDefault();

我得到一个错误:

数据读取器具有多个字段。 多个字段对于EDM原语或枚举类型无效。

错误(也许是令人费解的)只是告诉您存储过程正在返回多列数据,但是您正在尝试将所有内容都转换为int 您需要创建一个映射到存储过程返回的类的类,并将其用作SqlQuery的泛型类型参数。 例如,如果返回名为FooBar列:

public class MyListDto
{
    public string Foo { get; set; }
    public string Bar { get; set; }
}

然后:

var outPutList = db.Database.SqlQuery<MyListDto>("spInsertToBaseFile @myList", param).FirstOrDefault();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM