2011-02-10 21 views
0

(コードファーストを使用して)E​​ntity Frameworkにエンティティを挿入しようとしているときにキャスト例外が発生します。Entity Frameworkにエンティティを挿入しようとしたときにキャスト例外エラーが発生しました。

キャスト例外は、このコードから

を "(エンティティ)を型にキャストすることは不可能... Collection'1(エンティティ)" のようなものです:

public virtual T Insert(T entity) 
{ 
     return Context.Set<T>().Add(entity); 
} 

私はなぜ把握することはできません。私はかなりすべてのことが正しいと思っています。

ポストエンティティ

public class Post 
    { 
     public long PostId { get; private set; } 
     public DateTime date { get; set; } 
     [Required] 
     public string Subject { get; set; } 
     public User User { get; set; } 
     public Category Category { get; set; } 
     [Required] 
     public string Body { get; set; } 

     public virtual ICollection<Tag> Tags { get; private set; } 

     public Post() 
     { 
      Category = new Category(); 
      if (Tags == null) 
       Tags = new Collection<Tag>(); 
     } 

     public void AttachTag(string name, User user) 
     { 
      if (Tags.Count(x => x.Name == name) == 0) 
       Tags.Add(new Tag { 
        Name = name, 
        User = user 
       }); 
      else 
       throw new Exception("Tag with specified name is already attached to this post."); 
     } 

     public Tag DeleteTag(string name) 
     { 
      Tag tag = Tags.Single(x => x.Name == name); 
      Tags.Remove(tag); 

      return tag; 
     } 

     public bool HasTags() 
     { 
      return (Tags.Count > 0); 
     } 
    } 

タグエンティティ

public class Tag 
{ 
    public long TagId { get; private set; } 
    public string Name { get; set; } 
    // Qui a ajouté le tag ? 
    public User User { get; set; } 
} 

マッピング

public class PostMap: EntityTypeConfiguration<Post> 
{ 
    public PostMap() 
    { 
     ToTable("Posts"); 
     HasKey(x => x.PostId); 
     Property(x => x.Subject) 
      .HasColumnType("varchar") 
      .HasMaxLength(256) 
      .IsRequired(); 
     Property(x => x.Body) 
      .HasColumnType("text") 
      .IsRequired(); 
     HasMany(x => x.Tags); 
     HasOptional(x => x.Tags); 
    } 
} 

class TagMap : EntityTypeConfiguration<Tag> 
{ 
    public TagMap() 
    { 
     ToTable("Tags"); 
     HasKey(x => x.TagId); 
     Property(x => x.Name) 
      .HasColumnType("varchar") 
      .HasMaxLength(256) 
      .IsRequired(); 
     HasRequired(x => x.User); 


} 
    } 

おかげでたくさん。

答えて

0

解決策が見つかりました。ここで

ポストのための正しいマッピングシナリオ:

public PostMap() 
     { 
      ToTable("Posts"); 
      HasKey(x => x.PostId); 
      Property(x => x.Subject) 
       .HasColumnType("varchar") 
       .HasMaxLength(256) 
       .IsRequired(); 
      Property(x => x.Body) 
       .HasColumnType("text") 
       .IsRequired(); 
      HasRequired(x => x.User); 
      HasMany(x => x.Tags).WithOptional(); 
     } 

タグのコレクションはオプションで指定することが重要です。このシナリオではどちらが当てはまりますか。ポストにはゼロタグを付けることができます。

HasMany(x => x.Tags).WithOptional();

0

1つの要素を含むコレクションではなく、1つの要素をInsertメソッドに渡してください。

+0

私はこれに関するいかなる制御もしていません。 – Rushino

関連する問題