使用内部连接从 Dapper 获取数据

Get data using inner join from Dapper

我正在一个项目上进行数据库操作并开发 WinForms App C#,我正在使用 Dapper 从数据库中获取数据,我陷入了需要使用内部联接检索数据的情况。例如。我有两个表 Authors 和 Book 如下:

public class Authors
{
    public int AuthorId { get; set; }
    public string AuthorName { get; set; }
}
public class Book
{
    public int BookId { get; set; }
    public string AuthorId { get; set; }
    public string Title { get; set; }
    public string Description { get; set; }
    public int Price { get; set; }
}

现在在 SQL 服务器中,我可以使用以下查询轻松地从中获取数据:

select B.Title,b.Description,b.Price,A.AuthorName from author A inner join book B on A.AuthorId = B.Authorid

但是我不知道如何使用 dapper multi mapping 来做到这一点,我也看到了像 This 这样的文章,但无法理解它是如何工作和拆分的。如果我的 class 设计能得到相同的解决方案,我会很棒。 谢谢

这是我想要的输出:ResultSet

根据您链接的结果,您可以这样做:

public class Result
{
    public string Title { get; set; }
    public string Description { get; set; }
    public int Price { get; set; }
    public string AuthorName { get; set; }
}

connection.Query<Result>("SELECT B.Title,B.Description,B.Price,A.AuthorName FROM Author A INNER JOIN Book B on A.AuthorId = B.Authorid");

或者您可以使用动态类型。

如果您想拥有 collection 本书的作者,那就是另一回事了。然后你会这样做(为了示例选择 *):

var sql = "SELECT * FROM Author A INNER JOIN Book B on A.AuthorId = B.Authorid";
var result = connection.Query<Book, Author, Book>(sql,
(b, a) => { b.Author = a; return b; }, splitOn: "AuthorId");

splitOn参数应该这样理解:如果查询中所有的列都是从左到右排列的,那么左边的值属于第一个class 右边的值属于第二个 class.