回答

收藏

Dapper多个连接的映射SQL查询

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

我想将复杂的对象映射到两个内部连接查询的简化结果中。我知道我们已经解决了映射内部连接的解决方案,但我想映射两个内部连接的结果。3 c5 p! N4 D/ _' `' Z; `# g
这是场景:
  H2 {/ n6 G* B1 j; s; h. E' I3 v  z我的课程是:" {% L" g, U1 a8 D0 a% F
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作为列表。# T0 |4 x0 W8 F
现在,这是我想要的List使用正确数据填充查询的基础:; h' n% P9 Q. P! _, _. \7 Z
SELECT *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到目前为止,我已经尝试过这
+ Z8 ~: B- @* d  S( XorderDetail = 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。
2 j: r$ B8 U( n( j1 B) [" e) ]                                                               
9 R$ ]. X! @1 U1 b- z! F0 H% u6 O    解决方案:                                                               
' D& [/ ~# Z- @' R& q& p$ k                                                                我尽力解决。
( ~$ k& ~, C/ Z9 @# t这是根据我的更简单,更准确的解决方案:# l7 m% J1 F  T) s( B; b
var 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();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则