Dapper调用存储过程并将结果映射到类

Max*_*iev 11 c# sql-server stored-procedures dapper

我有一个T-SQL存储过程:

CREATE PROCEDURE [dbo].[GetRequestTest] 
        @RequestId UNIQUEIDENTIFIER
AS
BEGIN
    SELECT 
        Request.Amount,
        Request.Checksum 
    FROM 
        Request 
    WHERE
        RequestId = @RequestId
END
Run Code Online (Sandbox Code Playgroud)

C#映射类:

public class CustomTest : Itest
{
    public decimal Amount {get;set;}
    public string Checksum { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我正在调用尝试使用Dapper调用存储过程:

public void Load(CustomTest obj, Guid RequestId)
{
    using (var con = base.GetClosedConnection())
    {
        con.Open();

        var p = new DynamicParameters();
        p.Add("@RequestId", dbType: DbType.Guid, direction: ParameterDirection.Input);               

        var result = con.ExecuteReader("[dbo].[GetRequestTest]", param: p, commandType: CommandType.StoredProcedure);

        while (result.Read())
             obj.Amount = (decimal)result["Amount"];
    }            
}
Run Code Online (Sandbox Code Playgroud)

但结果是空的

我试图调用将存储过程中的SQL语句直接放入C#代码 - 它工作正常,但它不适用于存储过程.

任何想法 - 如何使它工作?

Ngu*_*ien 16

你打错了方法:

public void Load(CustomTest obj, Guid RequestId)
{
    using (var con = base.GetClosedConnection())
    {
        con.Open();                

        //result is list of CustomTest
        var result = db.Query<CustomTest>("GetRequestTest", new {RequestId},
                         commandType: CommandType.StoredProcedure);
    }            
}
Run Code Online (Sandbox Code Playgroud)

如何使用dapper:https://github.com/StackExchange/dapper-dot-net