如何使用Dapper有效地选择聚合对象?
让我们说我有一系列形成聚合的对象。
public class C{ public string Details {get;set;} } public class B{ public string Details {get;set;} public List Items {get;set;} } public class A{ public long ID {get;set;} public string Details {get;set;} public List Items {get;set;} }
使用Dapper,从数据库中的表中填充这些内容的最佳方法是什么(在我的情况下,它是postgres,但这不重要)。 示例中的表几乎是一对一的对象模型。 类的Items属性,表示与每个从属对象的外键关系。 即3个表,A与B具有一对多关系,B与C具有一对多关系。
因此,对于给定的AI ID,我希望我的对象也拥有所有子数据。
我最好的猜测是我应该以某种方式使用QueryMultiple,但我不确定如何做到最好。
我认为我在这里提出的帮助: 创建对象层次结构的Multi-Mapper可能会有所帮助。
var mapped = cnn.QueryMultiple(sql) .Map ( A => A.ID, B => B.AID, a, bees => { A.Items = bees}; );
假设您扩展GridReader并使用映射器:
public static IEnumerable Map ( this GridReader reader, Func firstKey, Func secondKey, Action> addChildren ) { var first = reader.Read().ToList(); var childMap = reader .Read() .GroupBy(s => secondKey(s)) .ToDictionary(g => g.Key, g => g.AsEnumerable()); foreach (var item in first) { IEnumerable children; if(childMap.TryGetValue(firstKey(item), out children)) { addChildren(item,children); } } return first; }
您可以扩展此模式以使用3级层次结构。
上述就是C#学习教程:如何使用Dapper有效地选择聚合对象?分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/cdevelopment/998811.html