Dapperで1対多のマッピング

c# dapper one-to-many sql tsql

質問

これを理解しようとしていますが、私はそれを働かせることはできません。このクエリ:

select MultiCollections.*, Collections.* from MultiCollections 
left join MultiCollectionCollections on MultiCollections.Id = MultiCollectionCollections.MultiCollectionId
left join  Collections on MultiCollectionCollections.CollectionId = Collections.Id
where MultiCollections.UserId=5

これはこのデータを返します:

ここに画像の説明を入力ご覧のとおり、1行目と2行目は同じタイトルのものです。それらの背後にあるデータは本です。 3列目と4列目もコレクションですが、本はありません。

自分のコードに2つのオブジェクトがあります:MultiCollection Collection

両方とも、クエリの結果として与えられたデータに対応しています.Id、UserId、およびTitleは、オブジェクトMultiCollection用です。他のデータはオブジェクトCollection用です。

私は私のC#コードで3つのMultiCollectionを見ることを期待しています:Action Drama Fiction

アクションには2つのコレクションがあります。ドラマとフィクションは空でなければなりません。

代わりに、私は4つのMultiCollectionsを取得し、いずれもコレクションを含んでいません。私のC#コード:

public IEnumerable<MultiCollection> GetAll(int userId)
    {
        string query = @"select MC.*, C.* from MultiCollections  MC
                        left join MultiCollectionCollections MCC on MC.Id = MCC.MultiCollectionId
                        left join  Collections C on MCC.CollectionId = C.Id
                        where UserId=" + userId;

        using (DbConnection connection = ConnectionFactory())
        {
            connection.Open();
            return connection.Query<MultiCollection, List<Collection>, MultiCollection>(query,
                (a, s) =>
                {
                    a.Collections = s;
                    return a;
                });
        }
    }

コードを実行するとき、私はこれを期待します:

Action    
    Collections    
       -> Book 1    
       -> Book 2     
Drama    
   Collections    
       Null     
Fiction    
    Collections    
        Null

私は何が間違っているのか分かりません。

人気のある回答

あなたのC#コードは次のようになります:

public IEnumerable<MultiCollection> GetAll(int userId)
{
    string query = @"select MC.*, C.* from MultiCollections  MC
                    left join MultiCollectionCollections MCC on MC.Id = MCC.MultiCollectionId
                    left join  Collections C on MCC.CollectionId = C.Id
                    where UserId=" + userId;

    using (DbConnection connection = ConnectionFactory())
    {
        connection.Open();
        return connection.Query<MultiCollection, Collection, MultiCollection>(query,
            (a, s) =>
            {
                a.Collections = new List<Collection>();
                a.Collections.Add(s);
                return a;
            }, splitOn: "MultiCollectionId,CollectionId"););
    }
}

注目.Query<MultiCollection, Collection, MultiCollection>Collection List<Collection>ではなく、セッターではなく.add()を実行していることに.add().add()



ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ