运维开发网

Dapper应用程序返回多个结果集

运维开发网 https://www.qedev.com 2022-08-17 17:06 出处:网络
这篇文章介绍了使用Dapper返回多个结果集的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

这篇文章介绍了使用Dapper返回多个结果集的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

使用Dapper的QueryMultiple方法,可以一次执行多个SQL语句并返回多个结果集。代码如下所示

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Configuration;using Dapper;using System.Data;using System.Data.SqlClient;using DapperAppQueryMultiple.Model;namespace DapperAppQueryMultiple{ class Program { static void Main(string[] args) { // 定义连接字符串 string conn = ConfigurationManager.ConnectionStrings["AppConnection"].ConnectionString; using (IDbConnection connection = new SqlConnection(conn)) { var sql = @"SELECT * FROM Users WHERE UserId=@UserId; SELECT * FROM Product WHERE ProductId=@ProductId"; var queryMulti = connection.QueryMultiple(sql, new { UserId = 1, ProductId=3 }); // 注意:Read获取的时候必须是按照上面返回表的顺序 比如上面先查询的Users表,那么Read的时候必须先返回Users表,否则返回没有数据 var users = queryMulti.Readlt;Usergt;(); var products = queryMulti.Readlt;Productgt;(); Console.WriteLine("*****产品信息*****"); // 循环遍历输出 products.AsListlt;Productgt;().ForEach(p =gt; { Console.WriteLine("产品名称:"+p.ProductName+" 价格:"+p.Price); }); Console.WriteLine("*****产品信息*****"); Console.WriteLine("*****用户信息*****"); users.AsListlt;Usergt;().ForEach(p =gt; { Console.WriteLine("用户姓名:"+p.UserName+" 邮箱:"+p.Email+" 地址:"+p.Address); }); Console.WriteLine("*****用户信息*****"); } Console.ReadKey(); } }}

程序运行结果:


注意:读取时必须按上面的顺序返回表,比如先查询的Users表,所以读取时必须先返回Users表,否则没有数据返回。ReadltTgt上述代码中的T泛型类不必与数据库表名相同。上面代码中的T泛型类是User,数据库表名是Users。

以下代码演示了不同的退货单:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Configuration;using Dapper;using System.Data;using System.Data.SqlClient;using DapperAppQueryMultiple.Model;namespace DapperAppQueryMultiple{ class Program { static void Main(string[] args) { // 定义连接字符串 string conn = ConfigurationManager.ConnectionStrings["AppConnection"].ConnectionString; using (IDbConnection connection = new SqlConnection(conn)) { var sql = @"SELECT * FROM Users WHERE UserId=@UserId; SELECT * FROM Product WHERE ProductId=@ProductId"; var queryMulti = connection.QueryMultiple(sql, new { UserId = 1, ProductId=3 }); // 先返回Product表的查询数据 var products = queryMulti.Readlt;Productgt;(); var users = queryMulti.Readlt;Usergt;(); Console.WriteLine("*****产品信息*****"); // 循环遍历输出 products.AsListlt;Productgt;().ForEach(p =gt; { Console.WriteLine("产品名称:"+p.ProductName+" 价格:"+p.Price); }); Console.WriteLine("*****产品信息*****"); Console.WriteLine("*****用户信息*****"); users.AsListlt;Usergt;().ForEach(p =gt; { Console.WriteLine("用户姓名:"+p.UserName+" 邮箱:"+p.Email+" 地址:"+p.Address); }); Console.WriteLine("*****用户信息*****"); } Console.ReadKey(); } }}

上面的代码只修改返回到表中的数据,程序运行如下:


示例代码下载地址:单击此处下载

这就是本文关于使用Dapper返回多个结果集的内容。希望对大家的学习有所帮助

0

精彩评论

暂无评论...
验证码 换一张
取 消