web-dev-qa-db-ja.com

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"];
    }            
}

しかし、結果はnullです

ストアドプロシージャから直接C#コードにSQLステートメントを配置するために呼び出しようとしました-それは正常に機能しますが、ストアドプロシージャでは機能しません。

何かアイデア-それを機能させる方法は?

11
Max Iakovliev

間違ったメソッドを呼び出します:

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

Dapperの使用方法: https://github.com/StackExchange/dapper-dot-net

16
Nguyen Kien
using (var con = base.GetClosedConnection())
{
    var result = conn.Query<CustomTest>("exec [dbo].[GetRequestTest] @id", new {Id = RequestId});
}

列名のストアドプロシージャまたはクエリの戻り値は、CustomTestのプロパティ名(Amount、Checksumなど)と同じである必要があります。その結果、適切なデータで満たされたIEnumerableを受け取ります。

2
Alex Erygin