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

标签 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

C#映射类:

public class CustomTest : Itest
{
    public decimal Amount {get;set;}
    public string Checksum { get; set; }
}

我正在尝试使用 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"];
    }            
}

但结果为空

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

任何想法 - 如何让它发挥作用?

最佳答案

你调用了错误的方法:

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);
    }            
}

如何使用小巧玲珑:https://github.com/StackExchange/dapper-dot-net

关于c# - Dapper 调用存储过程并将结果映射到类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31333937/

相关文章:

MySQL SELECT 对存储过程中的 NOT NULL 列返回 NULL

postgresql - 如何从函数本身内部获取调用函数的语句?

c# - Xaml:在 DataTemplate 中绑定(bind)集合

c# - 强制 .NET、多线程 volatile 优化错误

c# - 自定义控件覆盖命令按钮

sql - 无法解决 equal to 操作中 "Latin1_General_BIN"和 "Latin1_General_CI_AS"之间的排序规则冲突

c# - 如何从存储过程返回的表中获取列名

c# - 如何返回带有错误消息或异常的 NotFound() IHttpActionResult?

sql-server - SQL Server - BIT 数据类型问题

sql iif语句连接表问题