Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Dapper.NET i przechowywany proc z wieloma zestawami wyników

QueryMultiple wspiera zdolność radzenia sobie z wieloma zestawami wyników. Jedynym ograniczeniem projektowym, które dodaliśmy, było całkowite wyłączenie buforowania dla czytnika siatki. Oznacza to, że cały interfejs API przesyła strumieniowo .

W najprostszym przypadku możesz użyć:

var grid = connection.QueryMultiple("select 1 select 2");
grid.Read<int>().First().IsEqualTo(1);
grid.Read<int>().First().IsEqualTo(2);

W nieco bardziej wyrafinowanym przypadku możesz robić takie szalone rzeczy:

var p = new DynamicParameters();
p.Add("a", 11);
p.Add("r", dbType: DbType.Int32, direction: ParameterDirection.ReturnValue);

connection.Execute(@"create proc #spEcho
@a int
as 
begin

select @a Id, 'ping' Name, 1 Id, 'pong1' Name
select @a Id, 'ping' Name, 2 Id, 'pong2' Name
return @a
end");

var grid = connection.QueryMultiple("#spEcho", p, 
                                     commandType: CommandType.StoredProcedure);

var result1 = grid.Read<dynamic, dynamic, Tuple<dynamic, dynamic>>(
                  (a, b) => Tuple.Create((object)a, (object)b)).ToList();
var result2 = grid.Read<dynamic, dynamic, Tuple<dynamic, dynamic>>(
                  (a, b) => Tuple.Create((object)a, (object)b)).ToList();

((int)(result1[0].Item1.Id)).IsEqualTo(11);
((int)(result1[0].Item2.Id)).IsEqualTo(1);

((int)(result2[0].Item1.Id)).IsEqualTo(11);
((int)(result2[0].Item2.Id)).IsEqualTo(2);

p.Get<int>("r").IsEqualTo(11);

Musisz dodać tę instrukcję using, aby włączyć QueryMultiple .

using Dapper; /* to add extended method QueryMultiple public static GridReader QueryMultiple(this IDbConnection cnn, string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null); */


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Użyj FILE_IDEX(), aby zwrócić identyfikator pliku bazy danych w SQL Server

  2. Różnica między bazą danych a schematem

  3. Przechowywanie danych UTF-16/Unicode w SQL Server

  4. Kiedy powinienem używać zmiennej tabeli a tabeli tymczasowej w serwerze sql?

  5. Jak wdrożyć aplikację z bazą danych serwera sql na klientach