Coder Social home page Coder Social logo

Comments (1)

baynezy avatar baynezy commented on May 28, 2024

So in the end I worked it out. I did the following based on https://www.learndapper.com/relationships

var documents = await connection.QueryAsync<DocumentDto, LabelDto, CollaboratorDto, DocumentDto>(
            GetDocumentSql,
            (doc, label, collaborator) => {
                if (label is not null && label.LabelId != Guid.Empty) // empty guid means no label
                {
                    doc.Labels.Add(label);
                }
                if (collaborator.ProfileId != Guid.Empty) // empty guid means no collaborator
                {
                    doc.Collaborators.Add(collaborator);
                }
                return doc;
            }, 
            new
            {
                Id = documentId.ToString()
            },
            splitOn: "LabelId,DocumentId");
        
        var result = documents
            .GroupBy(d => d.Id)
            .Select(g =>
        {
            var groupedDocument = g.First();
            groupedDocument.Labels = g.Select(d => d.Labels.Single())
                .GroupBy(l => l.LabelId)
                .Select(l=> l.First())
                .ToList();
            groupedDocument.Collaborators = g.Select(d => d.Collaborators.Single())
                .GroupBy(c => c.ProfileId)
                .Select(c => c.First())
                .ToList();
            return groupedDocument;
        });

I am not in love with the catalogue of LINQ, but it does exactly what I need.

from dapper.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.