回答

收藏

Dapper多个连接的映射SQL查询

技术问答 技术问答 304 人阅读 | 0 人回复 | 2023-09-14

我想将复杂的对象映射到两个内部连接查询的简化结果中。我知道我们已经解决了映射内部连接的解决方案,但我想映射两个内部连接的结果。
' z+ b( ~* N9 K, e% V" {' ?这是场景:
6 m7 Q. E. }4 Z0 v3 j* _我的课程是:
) n/ ~/ a+ C9 c+ _public class Order    public int id { get; set;    public string order_reference { get; set;    public string order_status { get; set;    public List OrderLines { get; set; }}public class OrderLine{    public int id { get; set;    public int order_id { get; set;    public string product_number { get; set;    public List OrderLineSizes { get; set; }}public class OrderLineSize{    public int id { get; set;    public int order_line_id { get; set;    public string size_name { get; set; }}订单将OrderLines并将作为列表OrderLine作为OrderLineSizes作为列表。
0 D( D0 \/ V9 s4 O' g/ h9 k4 s
现在,这是我想要的List使用正确数据填充查询的基础:
+ Z1 ?) X, _; U# n: y! W! W9 F. USELECT *FROM orders_mstr oINNER JOIN order_lines ol ON o.id = ol.order_idINNER JOIN order_line_size_relations ols ON ol.id = ols.order_line_id到目前为止,我已经尝试过这
, T% Q& x3 u0 KorderDetail = o);                                                                                                      if (orderDetail.OrderLines == null)                        orderDetail.OrderLines = new List();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;orderDetail.OrderLines.Add(ol);                    return orderDetail;           .AsQueryable();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;var resultList = lookup.Values;orderDetail = o);                    }                    if (orderDetail.OrderLines == null)                        orderDetail.OrderLines = new List();                    orderDetail.OrderLines.Add(ol);                    return orderDetail;                }).AsQueryable();            var resultList = lookup.Values;我可以成功地使用这种方法OrderLine映射订单对象,但我也想填写正确的数据OrderLineSizes。7 R. Z8 u0 |1 W0 [. \) z5 t
                                                               
! b& N/ J. {" I    解决方案:                                                                * F: X2 \. H! U( R) P; p
                                                                我尽力解决。
/ g3 f& i3 |, v. ~9 p这是根据我的更简单,更准确的解决方案:
9 f; q7 a4 I6 Y, i! B3 `; n" a3 xvar lookup = new Dictionary<i>();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;var lookup2 = new Dictionary<i>();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;connection.Query(@&quot;                    SELECT o.*,ol.*,ols.*                    FROM orders_mstr o                    INNER JOIN order_lines ol ON o.id = ol.order_id                    INNER JOIN order_line_size_relations ols ON ol.id = ols.order_line_id                               &quot;,(o,ol,ols) =>                                                   OrderDetail orderDetail;                if (!lookup.TryGetValue(o.id,out orderDetail))                                                           lookup.Add(o.id,orderDetail = o);                                                         OrderLine orderLine;                if (!lookup2.TryGetValue(ol.id,out orderLine))                                                           lookup2.Add(ol.id,orderLine = ol);                    orderDetail.OrderLines.Add(orderLine);                                                         orderLine.OrderLineSizes.Add(ols);                return orderDetail;        ).AsQueryable();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;var resultList = lookup.Values.ToList();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则