在本文中,我们将介绍如何使用DAPPER从单个数据库调用中读取数据库中的多个结果集。我们将看看我们可能希望这样做的场景,以及如何使用它的Query和QueryMultiple方法更简洁地实现这一点。 当我们谈论以数据为中心的应用程序时,可能会出现一些场景,在这些场景中我们可能希望从数据库中检索多重结果。多个结果集既可以是相关的,也可以是无关的。要做到这一点,我们不需要对数据库进行多次往返,而是可以在一次数据库调用本身中实际使用dapper检索结果,然后将结果映射到代码中的所需对象。 在我们继续并开始研究如何做到这一点之前,让我们首先试着理解在我们的应用程序中可能希望做到这一点的场景: 1、查询无关实体:所请求的实体根本不相关。 2、查询具有1至多个关系的相关实体:被请求的实体具有1对多的关系,我们需要在代码中处理多个结果集 3、查询具有1至1关系的相关实体:被请求的实体具有1-1关系,我们需要在代码中执行处理多个映射 在第一个场景中,我们有完全不相关的实体,因此基本上,我们只想执行两个独立的查询来检索数据,然后将其映射到这些实体。在第二个场景中,返回的实体与1-多相关,因此我们希望检索数据,然后将结果映射到具有1至多个关系的POCO中。最后,在第三个场景中,返回的实体是1-1,因此我们希望检索数据,然后将结果映射到具有1-1关系的POCO中。 现在让我们看看一些代码,了解如何使用Dapper来实现这一切。 所有这些都可以通过DAPPER的查询、QueryMultiple和Read方法进行归档。现在让我们把重点放在如何在代码中执行这些操作。
查询无关实体
假设我们想从API中检索书籍和视频列表。我们可以通过两个简单的选择所有查询来实现这一点,数据库结果看起来如下:
现在,为了能够从代码中执行同样的操作,我们首先需要定义我们的实体:
复制代码
1 public class Book
2 {
3 public int ID { get; set; }
4 public string BookName { get; set;}
5 public string ISBN { get; set; }
6 }
7
8 public class Video
9 {
10 public int ID { get; set; }
11 public string VideoName { get; set; }
12 }
复制代码
使用这些模型,让我们看看如何只使用一个数据库调用来使用DAPPER检索这些结果:
复制代码
1 public IActionResult Index()
2 {
3 // define our SQL query - it contains mulitple queries seprated by ;
4 var query = "SELECT * from Books; Select * from Videos";
5
6 // Execute the query
7 var results = dbConnection.QueryMultiple(query);
8
9 // retrieve the results into the respective models
10 var books = results.Read();
11 var videos = results.Read