当前位置: 代码迷 >> 综合 >> 【2021-03-17】The entity type ‘Video‘ is part of a hierarchy, but does not have a discriminator value
  详细解决方案

【2021-03-17】The entity type ‘Video‘ is part of a hierarchy, but does not have a discriminator value

热度:33   发布时间:2023-12-14 20:17:05.0

问题

初始化数据库失败,错误部分源代码如下:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    // Movie、Tv一起放在Video表中,以Type属性区分;modelBuilder.Entity<Video>().HasDiscriminator<VideoType>("Type").HasValue<Movie>(VideoType.Movie).HasValue<Tv>(VideoType.Tv);省略......

我有一个父类Video(影视作品),两个继承自它的子类Movie(电影)和Tv(电视剧),所有的Video要么是Movie要么是Tv,我打算将他们都放在一个Video表中。
因此用HasDiscriminator设置鉴别器,鉴别器的鉴别对象是enum枚举类型VideoType,包含两项MovieTv
但这个报错却还是说“没有为Video表设置鉴别的依据”。

错误原因

即使我设计的程序只允许出现MovieTv这两个子类的实体,不会出现父类Video,但仍应该为父类Video设置鉴别依据。
参考这个stackflow页面末尾的一个回答。

改正

1、先去enum VideoType加一个Video,虽然它可能永远都用不到
在这里插入图片描述

2、再去DbContextVideo加一个鉴别HasValue(VideoType.Video)

modelBuilder.Entity<Video>().HasDiscriminator<VideoType>("Type").HasValue<Video>(VideoType.Video)     // 加了这个.HasValue<Movie>(VideoType.Movie).HasValue<Tv>(VideoType.Tv);

问题解决!

  相关解决方案