Store the Dapper Call stored procedure and map the result to the class

I have a T-SQL stored procedure:

CREATE PROCEDURE [dbo].[GetRequestTest] @RequestId UNIQUEIDENTIFIER AS BEGIN SELECT Request.Amount, Request.Checksum FROM Request WHERE RequestId = @RequestId END 

C # mapping class:

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

I invoke an attempt to call a stored procedure using 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"]; } } 

But the result is null

I tried calling to put the SQL statement from the stored procedure directly into C # code - and it works fine, but does not work with the stored procedure.

Any ideas - how to make it work?

+8
c # sql-server stored-procedures dapper
source share
2 answers

You are calling the wrong method:

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

How to use dapper: https://github.com/StackExchange/dapper-dot-net

+7
source share
 using (var con = base.GetClosedConnection()) { var result = conn.Query<CustomTest>("exec [dbo].[GetRequestTest] @id", new {Id = RequestId}); } 
+1
source share

All Articles