相关疑难解决方法(0)

无法在Dapper中使用多映射

和Dapper一起玩,我对目前的结果非常满意 - 很有趣!

但现在,我的下一个场景是从两个表中读取数据 - a StudentAddress表.

Student表有一个主键StudentID (INT IDENTITY),Address有一个AddressID (INT IDENTITY).Student还有一个名为AddressID链接到Address表中的FK .

我的想法是创建两个类,每个表一个,具有我感兴趣的属性.另外,我在C#中将PrimaryAddress类型的属性Address放到我的Student类中.

然后我尝试在单个查询中检索学生和地址数据 - 我模仿Github页面上给出的样本:

var data = connection.Query<Post, User>(sql, (post, user) => { post.Owner = user; });
var post = data.First();
Run Code Online (Sandbox Code Playgroud)

在这里,检索a Post和a User,并将帖子的所有者设置为用户 - 返回的类型是Post- 正确吗?

所以在我的代码中,我为通用Query扩展方法定义了两个参数- Student作为第一个应该返回的参数,Address第二个参数将存储到学生实例中:

var student = _conn.Query<Student, Address> …
Run Code Online (Sandbox Code Playgroud)

c# dapper multi-mapping

17
推荐指数
1
解决办法
2万
查看次数

如何使用Dapper有效地选择聚合对象?

可以说我有一系列形成聚合的对象.

public class C{
 public string Details {get;set;}
}

public class B{
  public string Details {get;set;}
  public List<C> Items {get;set;}
}

public class A{
  public long ID {get;set;}
  public string Details {get;set;}
  public List<B> Items {get;set;}
}
Run Code Online (Sandbox Code Playgroud)

使用Dapper,从数据库中的表填充这些内容的最佳方法是什么(在我的情况下,它是postgres,但这应该无关紧要).示例中的表几乎是一对一的对象模型.类的Items属性,表示与每个从属对象的外键关系.即3个表,A与B具有一对多关系,B与C具有一对多的关系.

因此,对于给定的AI ID,我希望我的对象也拥有所有子数据.

我最好的猜测是我应该以某种方式使用QueryMultiple,但我不确定如何做到最好.

c# sql dapper

16
推荐指数
1
解决办法
7276
查看次数

标签 统计

c# ×2

dapper ×2

multi-mapping ×1

sql ×1