未在asp.net中显示的表之间的关系mvc5

时间:2016-12-17 12:52:09

标签: c# asp.net relational-database

我正在构建一个asp.net应用程序。我有两个课程,一个电影和一个指导课程,我实施了多对多的关系。

导演班

public class Director
{
    private ICollection<Film> _films;

    public Director()
    {
        _films = new List<Film>();
    }

    public int DirectorID { get; set; }

    public string fName { get; set; }

    public string lName { get; set; }

    public int Age { get; set; }

    public virtual ICollection<Film> Films
    {
        get { return _films; }
        set { _films = value; }
    }
}

电影课

public class Film
{
    private ICollection<Director> _directors;

    public Film()
    {
        _directors = new List<Director>();
    }

    public int FilmId { get; set; }

    public string Name { get; set; }

    public int Minutes { get; set; }

    public string AgeClassification { get; set; }

    public virtual ICollection<Director> Directors
    {
        get { return _directors; }
        set { _directors = value; }
    }
}

种子方法

protected override void Seed(FilmNetwork.Models.FilmNetworkContext context)
    {

        var films = new List<Film>
            {
                new Film() { FilmId = 1, Name = "The Dark Knight", Minutes = 152, AgeClassification = "15A" },
                new Film() { FilmId = 2, Name = "The Social Network", Minutes = 120, AgeClassification = "15A" },
                new Film() { FilmId = 3, Name = "Up In The Air", Minutes = 109, AgeClassification = "15A" },
                new Film() { FilmId = 4, Name = "Slumdog Millionaire", Minutes = 120, AgeClassification = "15A" },
                new Film() { FilmId = 5, Name = "The Wolf Of Wall Street", Minutes = 180, AgeClassification = "18" },
                new Film() { FilmId = 6, Name = "King Kong", Minutes = 221, AgeClassification = "12" },
                new Film() { FilmId = 7, Name = "Schindler's List", Minutes = 195, AgeClassification = "18" }
            };
            films.ForEach(f => context.Films.AddOrUpdate(film => film.Name, f));
            context.SaveChanges();



        var directors = new List<Director>
            {
                new Director() { DirectorID = 1, fName = "Christopher", lName = "Nolan", Age = 46,
                    Films = films.Where(f => (f.Name == "The Dark Knight")).ToList()},
                new Director() { DirectorID = 2, fName = "David", lName = "Fincher", Age = 54,
                    Films = films.Where(f => (f.Name == "The Social Network")).ToList() },
                new Director() { DirectorID = 3, fName = "Jason", lName = "Reitman", Age = 39,
                    Films = films.Where(f => (f.Name == "Up In The Air")).ToList() },
                new Director() { DirectorID = 4, fName = "Danny", lName = "Boyle", Age = 60,
                    Films = films.Where(f => (f.Name == "Slumdog Millionaire")).ToList() },
                new Director() { DirectorID = 5, fName = "Martin", lName = "Scorsese", Age = 74,
                    Films = films.Where(f => (f.Name == "The Wolf Of Wall Street")).ToList() },
                new Director() { DirectorID = 6, fName = "Peter", lName = "Jackson", Age = 55,
                    Films = films.Where(f => (f.Name == "King Kong")).ToList() },
                new Director() { DirectorID = 7, fName = "Steven", lName = "Spielberg", Age = 70,
                    Films = films.Where(f => (f.Name == "Schindler's List")).ToList() },
            };
            directors.ForEach(d => context.Directors.AddOrUpdate(director => director.lName, d));
            context.SaveChanges();

我有一个ajax搜索,它生成基于id的电影。它返回电影,导演领域的导演是空白的,因为某种原因关系没有实现。

1 个答案:

答案 0 :(得分:0)

你应该在这里添加导演:

new Film() { FilmId = 1, Name = "The Dark Knight", Minutes = 152, AgeClassification = "15A"  }

你也绝对需要有很多关系吗?当电影有一个以上的导演时,很多情况都没有,所以将一对多的关系添加起来会更简单。

如何实现一对多关系:

导演班

public class Director
{



    public int DirectorID { get; set; }

    public string fName { get; set; }

    public string lName { get; set; }

    public int Age { get; set; }

    public virtual ICollection<Film> Films{get;set;}

}

电影课

public class Film
{



    public int FilmId { get; set; }

    public string Name { get; set; }

    public int Minutes { get; set; }

    public string AgeClassification { get; set; }

    public virtual Director Director { get; set; }
}

然后就像这样添加:

new Film() { FilmId = 1, Name = "The Dark Knight", Minutes = 152, AgeClassification = "15A" Director = _context.directors.where(x=> x.ID == "1"// or whichever parameter you want to find director from list)  }