.Query 對於具有嵌套對象的T

c# dapper orm

可能重複:
如何使用Dapper有效地選擇聚合對象?

有沒有可能讓dapper實例化嵌套對象,如果是這樣,有沒有這個實例的例子?

對於大多數情況,.net原語對我來說已足夠,但並非總是如此。 hack可能是將外鍵包含在父類型中作為基元,然後根據這些實例進行實例化。我希望這不是必要的,因為它會在POCO模型中產生不必要的噪音。

一般承認的答案

我認為我在這裡提出的幫助: 創建對象層次結構的Multi-Mapper可能會有所幫助。

var mapped = cnn.QueryMultiple(sql)
   .Map<A,B,A>
    (
       A => A.ID, 
       B => B.AID,
       a, bees => { A.Items = bees};  
    );

假設您擴展GridReader並使用映射器:

public static IEnumerable<TFirst> Map<TFirst, TSecond, TKey>
    (
    this GridReader reader,
    Func<TFirst, TKey> firstKey, 
    Func<TSecond, TKey> secondKey, 
    Action<TFirst, IEnumerable<TSecond>> addChildren
    )
{
    var first = reader.Read<TFirst>().ToList();
    var childMap = reader
        .Read<TSecond>()
        .GroupBy(s => secondKey(s))
        .ToDictionary(g => g.Key, g => g.AsEnumerable());

    foreach (var item in first)
    {
        IEnumerable<TSecond> children;
        if(childMap.TryGetValue(firstKey(item), out children))
        {
            addChildren(item,children);
        }
    }

    return first;
}

您可以擴展此模式以使用3級層次結構。



許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因
許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因