.Query ネストされたオブジェクトを持つTの場合

c# dapper orm

質問

可能な重複:
Dapperを使用して集約オブジェクトを効率的に選択するにはどうすればよいですか?

ネストされたオブジェクトをインスタンス化するためにdapperを得ることは可能でしょうか?

ほとんどの場合、.netプリミティブで十分ですが、必ずしもそうではありません。ハックは、外部キーを親タイプにプリミティブとして含めることになり、その後、これらに基づいてインスタンス化することがあります。私はこれがPOCOモデルで望ましくないノイズを生成するので、これは必要ではないと考えています。

受け入れられた回答

私はここで提案するヘルパーだと思います: オブジェクト階層を作成するためのマルチマッパーは助けになるかもしれません。

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
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow