0

我有一个项目,我获得了一个必须使用的存储过程。它用于在数据库中创建新记录。它返回一个Int32表中记录的新 ID。它还有一个临时表,其中存储错误并在第二个结果中发回。所以基本上最后两行是

SELECT @NewID
SELECT * From @ErrorsTable

我必须使用实体框架来调用存储过程。我的问题我不知道如何获得两个返回结果。

从数据库更新时的默认设置是只返回一个Int32. 我尝试遵循一些示例,它们从存储过程中执行多个返回结果,但我认为这对我不起作用,因为所有示例都返回多个复杂类型,并且我混合了标量和复杂类型。

4

1 回答 1

0

所以我想我最终通过主要遵循此链接http://msdn.microsoft.com/en-us/data/jj691402.aspx上的仅代码代码选项来解决它

我向我的存储库添加了一个新方法,该方法返回称为存储过程并返回多个结果集。沿着这些思路

Public Object[] StoredProcCall(string storedProc, SqlDbParams sqlParams, type[] types)
{
    var cmd = dbContext.Database.Connection.CreateCommand();
    cmd.CommandText = storedProc;
    cmd.CommandType = CommandType.StoredProcedure;
    if(parameters != null)
        cmd.Parameters.AddRange(sqlParams);
    var reader = cmd.ExecuteReader();

    try
    {
        dbContext.Database.Connection.Open();
        object[] mObj = new object[types.Count];
        for(int i = 0; i < types.Count; i++)
        {
            System.Reflection.MethodInfo method = typeof(AutoMapper.Mapper).GetMethod("DynamicMap", new Type[] { typeof(object)});
            var generic = method.MakeGenericMethod(types[i]);
            objected mappedData = generic.Invoke(this, new object[] { reader});
            mObj[i] = mappedData;
            if(!reader.NextResult())
                break;

        }
        return mObj;
    }
    finally
    {
        dbContext.Database.Connection.Close();
    }

}

唯一的想法是,为了让它工作,我必须创建一个只包含一个属性的类,它是我的简单类型。并且数组中的每种类型都需要是 IEnumerable ,这在我的情况下是可以的。但这是我所做的基本工作,可以根据需要进行更改。

于 2014-08-18T22:07:10.780 回答