2010-12-08 29 views
2

J'essaye de modéliser un album qui a une collection de photos. Chaque album aura une collection de photos et une photo qui est un pouce. C'est ce que j'ai, mais EF ne semble pas aimer ça. J'utilise EF CPT5Modélisation de domaine et mappage avec EF CPT5

Le modèle:

public class Album : IEntity { 
    private DateTime _dateCreated; 
    public Album() { 
    _dateCreated = SystemTime.Now(); 
    Photos = new List<Photo>(); 
    } 

    public long Id { get; set; } 
    public string Name { get; set; } 
    public string Location { get; set; } 
    public DateTime DateCreated { get { return _dateCreated; } set { _dateCreated = value; } } 

    public virtual Site Site { get; set; } 
    public virtual Photo Thumbnail { get; set; } 
    public long ThumbnailId { get; set; } 
    public virtual ICollection<Photo> Photos { get; set; } 
} 



public class Photo : IEntity { 
    public Photo() { 
    _dateCreated = SystemTime.Now(); 
    } 
    private DateTime _dateCreated; 
    public long Id { get; set; } 
    public string Caption { get; set; } 
    public string FileName { get; set; } 
    public DateTime DateCreated<br/>{ get { return _dateCreated; } set { _dateCreated = value; } } 
    public long AlbymId { get; set; } 
    public virtual Album Album { get; set; } 
} 

Le code Mapping:

public class AlbumMap : EntityTypeConfiguration<Album> { 
    public AlbumMap() { 
    HasRequired(x => x.Thumbnail).WithMany().HasForeignKey(a => a.ThumbnailId).WillCascadeOnDelete(false); 
     Property(x => x.Location).IsVariableLength().HasMaxLength(80); 
     Property(x => x.Name).IsVariableLength().HasMaxLength(80).IsRequired(); 
    } 
} 

public class PhotoMap : EntityTypeConfiguration<Photo> { 
    public PhotoMap() { 
    HasRequired(p => p.Album).WithMany(a => a.Photos).HasForeignKey(p => p.AlbymId); 
    Property(x => x.FileName).IsVariableLength().HasMaxLength(255).IsRequired(); 
    Property(x => x.Caption).IsVariableLength().HasMaxLength(255); 
    Property(x => x.DateCreated); 
    ToTable("SiteAlbumPhotos"); 
    } 
} 

Contexte

public class Database : ObjectContext { 

     public Database(EntityConnection connection) : base(connection) { 
      ContextOptions.LazyLoadingEnabled = true; 
      ContextOptions.ProxyCreationEnabled = true; 
     } 

     private IObjectSet<User> _users; 
     private IObjectSet<Site> _sites; 
     private IObjectSet<SiteDonation> _donations; 
     private IObjectSet<SiteAnnouncement> _siteAnnouncements; 
     private IObjectSet<SiteData> _siteData; 
     private IObjectSet<SiteLink> _siteLinks; 
     private IObjectSet<SitePost> _sitePosts; 
     private IObjectSet<Theme> _theme; 
     private IObjectSet<Album> _siteAlbums; 
     private IObjectSet<Photo> _siteAlbumPhotos; 
     private IObjectSet<CommunityPost> _communityPosts; 
     private IObjectSet<CommunityComment> _communityComments; 

     public IObjectSet<User> Users { 
      get{ return _users ?? (_users = ObjectSet<User>()); } 
     } 
     public IObjectSet<Album> SiteAlbums { 
      get { return _siteAlbums ?? (_siteAlbums = ObjectSet<Album>()); } 
     } 
     public IObjectSet<Photo> SiteAlbumsPhotos { 
      get { return _siteAlbumPhotos ?? (_siteAlbumPhotos = ObjectSet<Photo>()); } 
     } 
     public IObjectSet<Site> Sites { 
      get{ return _sites ?? (_sites = ObjectSet<Site>()); } 
     } 

     public IObjectSet<SiteDonation> SiteDonations { 
      get { return _donations ?? (_donations = ObjectSet<SiteDonation>()); } 
     } 

     public IObjectSet<SiteAnnouncement> SiteAnnouncements { 
      get { return _siteAnnouncements ?? (_siteAnnouncements = ObjectSet<SiteAnnouncement>()); } 
     } 

     public IObjectSet<SiteData> SiteData { 
      get { return _siteData ?? (_siteData = ObjectSet<SiteData>()); } 
     } 

     public IObjectSet<SiteLink> SiteLinks { 
      get { return _siteLinks ?? (_siteLinks = ObjectSet<SiteLink>()); } 
     } 

     public IObjectSet<SitePost> SitePosts { 
      get { return _sitePosts ?? (_sitePosts = ObjectSet<SitePost>()); } 
     } 

     public IObjectSet<Theme> Themes { 
      get { return _theme ?? (_theme = ObjectSet<Theme>()); } 
     } 
     public IObjectSet<CommunityPost> CommunityPosts { 
      get { return _communityPosts ?? (_communityPosts = ObjectSet<CommunityPost>()); } 
     } 
     public IObjectSet<CommunityComment> CommunityComments { 
      get { return _communityComments ?? (_communityComments = ObjectSet<CommunityComment>()); } 
     } 

     public virtual IObjectSet<T> ObjectSet<T>() where T : class, IEntity { 
      return CreateObjectSet<T>(); 
     } 
     public virtual void Commit() { 
      SaveChanges(); 
     } 
    } 

DatabaseFactory

public class DatabaseFactory : Disposable, IDatabaseFactory 
    { 
     private static readonly ModelBuilder builder = CreateBuilder(); 
     private readonly DbProviderFactory _providerFactory; 
     private readonly string _connectionString; 
     private Database _database; 
     // 
     public DatabaseFactory(DbProviderFactory providerFactory, string connectionString) 
     { 
      Check.Argument.IsNotNull(providerFactory, "providerFactory"); 
      Check.Argument.IsNotNullOrEmpty(connectionString, "connectionString"); 
      _providerFactory = providerFactory; 
      _connectionString = connectionString; 
     } 
     // 
     public Database Get() 
     { 
      if(_database == null) 
      { 
       var connection = _providerFactory.CreateConnection(); 
       connection.ConnectionString = _connectionString; 
       //_database = builder.CreateModel(connection); LEG 1 CPT 3 
       //var ctx = dbModel.CreateObjectContext<ObjectContext>(_connectionString); LEG 1 CPT 3 
       //var modelBuilder = builder.CreateModel(); LEG 2 CPT 4 
       //_database = modelBuilder.CreateObjectContext<Database>(connection); LEG 2 CPT 4 
       //_database = modelBuilder.CreateObjectContext<Database>(connection); LEG 2 CPT 4 
       var modelBuilder = builder.Build(connection); 
       var dbModel = new DbModel(modelBuilder); 
       _database = dbModel.CreateObjectContext<Database>(connection); 

      } 

      return _database; 
     } 
     // 
     protected override void DisposeCore() 
     { 
      if (_database != null) 
      { 
       _database.Dispose(); 
      } 
     } 
     // 
     private static ModelBuilder CreateBuilder() 
     { 
      //ContextBuilder<Database> contextBuilder = new ContextBuilder<Database>(); 
      var contextBuilder = new ModelBuilder(); 
      //IEnumerable<Type> configurationTypes = typeof(DatabaseFactory) 
      // .Assembly 
      // .GetTypes() 
      // .Where(type => type.IsPublic && type.IsClass && !type.IsAbstract && !type.IsGenericType && typeof(StructuralTypeConfiguration).IsAssignableFrom(type) && (type.GetConstructor(Type.EmptyTypes) != null)); 

      //foreach (StructuralTypeConfiguration configuration in configurationTypes.Select(type => (StructuralTypeConfiguration)Activator.CreateInstance(type))) 
      //{ 
      // contextBuilder.Configurations.Add(configuration); 
      //} 
      contextBuilder.Configurations.Add(new CommunityCommentMap()); 
      contextBuilder.Configurations.Add(new CommunityPostMap()); 
      contextBuilder.Configurations.Add(new SiteAlbumMap()); 
      contextBuilder.Configurations.Add(new SiteAlbumPhotoMap()); 
      contextBuilder.Configurations.Add(new SiteAnnouncementMap()); 
      contextBuilder.Configurations.Add(new SiteDataMap()); 
      contextBuilder.Configurations.Add(new SiteDonationMap()); 
      contextBuilder.Configurations.Add(new SiteLinkMap()); 
      contextBuilder.Configurations.Add(new SiteMap()); 
      contextBuilder.Configurations.Add(new SitePostMap()); 
      contextBuilder.Configurations.Add(new ThemeMap()); 
      contextBuilder.Configurations.Add(new UserMap()); 
      return contextBuilder; 
     } 
    } 

Am I Modélisation et cartographie cela correctement? Je dois pouvoir créer un nouvel album sans spécifier de vignette. A partir de maintenant, tout fonctionne jusqu'à ce que j'essaie d'ajouter une vignette, puis j'obtiens cette erreur:

System.Data.UpdateException: Impossible de déterminer un ordre valide pour les opérations dépendantes. Des dépendances peuvent exister en raison de contraintes de clé étrangère, d'exigences de modèle ou de valeurs générées par le stockage.

à System.Data.Mapping.Update.Internal.UpdateTranslator.DependencyOrderingError (en restant IEnumerable`1) à System.Data.Mapping.Update.Internal.UpdateTranslator.ProduceCommands() à System.Data.Mapping.Update .Internal.UpdateTranslator.Update (IEntityStateManager stateManager, adaptateur IEntityAdapter) at System.Data.Objects.ObjectContext.SaveChanges (options SaveOptions) à PostHope.Infrastructure.DataAccess.Database.Commit() dans Database.cs: ligne 74 à PostHope.Infrastructure.DataAccess.IntegrationTests.BuildDatabase.Add_test_data_to_database() dans BuildDatabase.cs: ligne 252

Toute aide serait géniale!

Répondre

2

Nous avons abordé cette question par EF CTP4 here. Maintenant, voici la mise à jour pour EF CTP5 qui a été released plus tôt aujourd'hui.

public class Photo 
{ 
    public long PhotoId { get; set; }   
    [MaxLength(255)] 
    public string Caption { get; set; }   
    [MaxLength(255)][Required] 
    public string FileName { get; set; }   
    public DateTime DateCreated { get; set; } 
    public long AlbumId { get; set; }   
    public virtual Album Album { get; set; } 
} 

[Table("SiteAlbumPhotos")] 
public class Album 
{ 
    public long AlbumId { get; set; }   
    [MaxLength(80)][Required] 
    public string Name { get; set; }   
    [MaxLength(80)] 
    public string Location { get; set; }   
    public DateTime DateCreated { get; set; }     
    public long ThumbnailId { get; set; }     
    public virtual Photo Thumbnail { get; set; }     
    public virtual ICollection<Photo> Photos { get; set; } 
} 

public class PhotoMap : EntityTypeConfiguration<Photo> { 
    public PhotoMap() {    
     HasRequired(p => p.Album).WithMany(a => a.Photos) 
           .HasForeignKey(p => p.AlbumId); 
    } 
} 

public class AlbumMap : EntityTypeConfiguration<Album> { 
    public AlbumMap() { 
     HasRequired(a => a.Thumbnail).WithMany() 
            .HasForeignKey(a => a.ThumbnailId) 
            .WillCascadeOnDelete(false); 
    } 
} 

public class MyContext : DbContext { 
    public DbSet<Photo> Photos { get; set; } 
    public DbSet<Album> Albums { get; set; } 

    protected override void OnModelCreating(ModelBuilder modelBuilder) { 
     modelBuilder.Configurations.Add<Photo>(new PhotoMap()); 
     modelBuilder.Configurations.Add<Album>(new AlbumMap()); 
    } 
} 

Quels sont les résultats de ce schéma DB: alt text

+0

Merci encore! J'obtiens cette erreur lorsque j'essaie de créer la base de données: System.Data.UpdateException: Impossible de déterminer un ordre valide pour les opérations dépendantes. Des dépendances peuvent exister en raison de contraintes de clé étrangère, d'exigences de modèle ou de valeurs générées par le stockage. Des idées?? – Paul

+0

Avez-vous copié et collé mon modèle, ou modifié le vôtre en fonction de mon message? Le schéma de base de données que vous voyez dans ma réponse est capturé à la suite de l'exécution de ce modèle par rapport à CTP5, de sorte qu'il est testé et fonctionne à 100%. Si vous utilisez un code personnalisé, veuillez le poster afin que je puisse voir ce qui se passe là-bas. Merci. –

+0

J'utilise IObjectSet et ObjectContext dans mon contexte. Je n'ai pas encore reconstruit mon contexte et mon Repository pour utiliser DbContext et DbSet parce que je vais devoir réécrire un tas de tests et utiliser des Requêtes Compilées est différent. J'utilise également l'API fluide et non les annotations de données. Il y a beaucoup de code à poster je pense, si vous voulez, je peux vous donner accès au repo SVN. Merci encore. – Paul