回答

收藏

Dapper多个连接的映射SQL查询

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

我想将复杂的对象映射到两个内部连接查询的简化结果中。我知道我们已经解决了映射内部连接的解决方案,但我想映射两个内部连接的结果。
/ N, y3 D, J* _, D; O+ D, M这是场景:0 r6 h. e! A( z% f$ j4 B
我的课程是:
8 o# e* S3 J, n* X# m1 Ppublic 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作为列表。& X, z' T' f7 W6 d4 o
现在,这是我想要的List使用正确数据填充查询的基础:
. {, {: v9 U, ~3 ]- l/ L5 cSELECT *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到目前为止,我已经尝试过这
$ \9 Y8 q* z4 X, B" h' ^orderDetail = 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。
& L/ b% K4 E" K  f5 `! P3 L                                                                * k, p+ Y2 b. e9 X+ v6 t
    解决方案:                                                                $ K! G8 ?% e" h
                                                                我尽力解决。, c' R* b& X8 x- q2 p8 _: d
这是根据我的更简单,更准确的解决方案:3 M" M6 a( R5 Z8 e2 Y6 k
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();;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则