Entity Framework Core: включает много-много связанных объектов в WebAPI
Я не слишком знаком с .NET Framework, но решил попробовать ASP.NET Core и EF Core. Я хочу создать довольно простой бэкэнд Web API, но у меня возникают проблемы при работе со многими отношениями.
Я понимаю, что мне нужно создать таблицу отношений для двух сущностей, как в примере из этого поста:Как создать отношения «многие ко многим» с последними ночными сборками EF Core?
У меня также есть мой конструктор моделей, создающий отношения, как описано здесьhttp://ef.readthedocs.io/en/latest/modeling/relationships.html#many-to-many
Мой код выглядит так:
в DBContext:
protected override void OnModelCreating(ModelBuilder builder)
{
base.OnModelCreating(builder);
builder.Entity<MovieActor>().HasKey(x => new { x.MovieId, x.ActorId});
builder.Entity<MovieActor>()
.HasOne(m => m.Movie)
.WithMany(ma => ma.MovieActors)
.HasForeignKey(m => m.MovieId);
builder.Entity<MovieActor>()
.HasOne(m => m.Actor)
.WithMany(ma => ma.MovieActors)
.HasForeignKey(a => a.ActorId);
}
public DbSet<Movie> Movies { get; set; }
public DbSet<Actor> Actors { get; set; }
}
Модели:
namespace Test.Models
{
public class Movie
{
public int MovieId { get; set; }
public string Title { get; set; }
public DateTime ReleaseDate { get; set; }
public string Code { get; set; }
public string Path { get; set; }
public ICollection<MovieActor> MovieActors { get; set; }
}
public class Actor
{
public int ActorId { get; set; }
public string Name { get; set; }
public ICollection<MovieActor> MovieActors { get; set; }
}
public class MovieActor
{
public int MovieId { get; set; }
public Movie Movie { get; set; }
public int ActorId { get; set; }
public Actor Actor { get; set; }
}
}
Кажется, это работает по большей части. Я могу создавать новые объекты MovieActor и добавлять их в базу данных. Одна вещь, которая кажется странной, это то, что модели Movie и Actor теперь имеют свойство MovieActors, но оно всегда равно нулю, несмотря на то, что в таблице соединений есть записи.
Я не могу понять, как получить эти связанные объекты в моих контроллерах WebAPI. Мои навыки в Linq очень слабые, так что, может быть, мне просто нужно это освежить, но я не знаю, с чего начать. Когда я получаю фильм по идентификатору или получаю список всех фильмов, я бы хотел, чтобы в результате в объекте были какие-либо связанные актеры в массиве. То же самое и в другом направлении, когда я получаю актера, я хочу получить множество их фильмов.
Вот один из моих методов контроллера, пытающихся использовать эти отношения:
// POST: api/Movie
[HttpPost]
public IActionResult PostMovie([FromBody] MovieBundle Moviebundle)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
var _movie = _context.Movies.FirstOrDefault(m => m.Code == Moviebundle.Movie.Code);
if(_movie == null)
{
//Doesn't exist! add a new one
_movie = Moviebundle.Movie;
_context.Movies.Add(_movie);
_context.SaveChanges();
foreach (Actor actor in Moviebundle.actors)
{
//Try to look up by name
Actor _actor = _context.Actors.FirstOrDefault(a => a.Name == actor.Name);
//If they don't exist, add them to the DB
if (_actor == null)
{
_context.Actors.Add(actor);
_context.SaveChanges();
_actor = actor;
}
//This is what I'm using to create the M-t-M relationship
var link = new MovieActor { Actor = _actor, Movie = _movie };
_context.MovieActor.Add(link); //This line gives an error
}
} else
{
return new StatusCodeResult(StatusCodes.Status409Conflict);
}
try
{
_context.SaveChanges();
}
catch (DbUpdateException)
{
if (MovieExists(_movie.MovieID))
{
return new StatusCodeResult(StatusCodes.Status409Conflict);
}
else
{
throw;
}
}
return CreatedAtAction("GetMovie", new { id = _movie.MovieID }, _movie);
}