2016-04-02 8 views
0

Ich habe Artikel und Autor Klassen.Entity zum Modell Mapping in LINQ

Artikel Fetch wie so und Map-Entity zu Modell:

public List<Model.Article> GetArticleList() { 
    using (var db = new ArticlesContext()) { 
     return db.Articles.Select(t => new Model.Article() { 
      Author = MapUserEntityToModel(db.Users.FirstOrDefault(u => u.UserID == t.UserID)) 
      Title = t.Title, 
      Teaser = t.Teaser 
      // etc 
     }).ToList(); 
    } 
} 

Dies funktioniert nicht, weil LINQ diese Funktion nicht zur Laufzeit ausgeführt werden kann. Was ist der einfachste und sauberste Weg, um das Mapping zu machen?

Hier sind Modelle:

namespace Model { 
    public class Article { 
     public string Title { get; set; } 
     public string Teaser { get; set; } 
     public User Author { get; set; } 
     public DateTime DateAdded { get; set; } 
    } 

    public class User { 
     public string DisplayName { get; set; } 
     public string Email { get; set; } 
     public string Website { get; set; } 
     public string PasswordHash { get; set; } 
    } 
} 

Hier sind Einheiten:

namespace MyProj { 
    public class Article { 
     [Key] 
     public int ArticleID { get; set; } 
     public string Title { get; set; } 
     public string Teaser { get; set; } 
     public int UserID { get; set; } 
     public DateTime DateAdded { get; set; } 
    } 

    public class User { 
     [Key] 
     public int UserID { get; set; } 
     public string DisplayName { get; set; } 
     public string Email { get; set; } 
     public string Website { get; set; } 
     public string PasswordHash { get; set; } 
    } 

    public class ArticleContext : DbContext { 
     public ArticleContext() : base("name=conn") { 
      public DbSet<Article> Articles { get; set; } 
      public DbSet<User> Users { get; set; } 
     } 
    } 
} 

Antwort

0

Bevor weiter, Karte Ihre Beziehung in einer Navigationseigenschaft:

public class Article { 
    [Key] 
    public int ArticleID { get; set; } 
    public string Title { get; set; } 
    public string Teaser { get; set; } 

    [ForeignKey("UserID")] 
    public virtual User Author {get; set; } // navigation property 

    public int UserID { get; set; } 
    public DateTime DateAdded { get; set; } 
} 

Und dann nur Ihre Navigationseigenschaft zu seinem Äquivalent Modellprojekt:

public List<Model.Article> GetArticleList() { 
    using (var db = new ArticlesContext()) { 
     return db.Articles.Select(t => new Model.Article() { 
      Author = new Model.User { 
       DisplayName = t.User.DisplayName, 
       Email = t.User.Email, 
       Website = t.User.Website, 
       PasswordHash = t.User.PasswordHash 
      }, 
      Title = t.Title, 
      Teaser = t.Teaser 
      // etc 
     }).ToList(); 
    } 
} 
0

Sie brauchen nichts zu tun, nur db.Articles direkt zurück:

using Model; 

public List<Article> GetArticleList() { 

    using(var db = new ArticlesContext()) { 
     return db.Articles.ToList(); 
    } 
} 

Angenommen, Ihre EF Modell ist korrekt mit Foreign Keys eingerichtet, Ihr Article Typ wird eine träge Auswertung haben ated Author Eigenschaft, die ein User Objekt zurückgibt, wenn auf sie zugegriffen wird.