0

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

キャスト例外は、「... Collection'1(Entity)をtype(Entity)にキャストできません」のようなものです。

このコードから:

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);


}
    }

どうもありがとうございます。

4

2 に答える 2

0

単一の要素を含むコレクションではなく、単一の要素を Insert メソッドに渡したことを確認してください。

于 2011-02-10T10:04:29.130 に答える
0

解決策を見つけました。

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();
            HasRequired(x => x.User);
            HasMany(x => x.Tags).WithOptional();
        }

Tags コレクションがオプションであることを指定することが重要です。このシナリオではこれが当てはまります。投稿には、タグを付けなくてもかまいません。

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

于 2011-02-10T12:57:32.163 に答える