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ステートメントを配置するために呼び出しようとしました-それは正常に機能しますが、ストアドプロシージャでは機能しません。
何かアイデア-それを機能させる方法は?
間違ったメソッドを呼び出します:
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
using (var con = base.GetClosedConnection())
{
var result = conn.Query<CustomTest>("exec [dbo].[GetRequestTest] @id", new {Id = RequestId});
}
列名のストアドプロシージャまたはクエリの戻り値は、CustomTestのプロパティ名(Amount、Checksumなど)と同じである必要があります。その結果、適切なデータで満たされたIEnumerableを受け取ります。