2

我的 MVC5 项目视图对存在以下逻辑的 api/movies 进行 api 调用:

(首先,这就是 moviesDto 的实例化方式):

var moviesQuery = _context.Movies.Include(m => m.Genre);
var moviesDto = moviesQuery.ToList()
            .Select(Mapper.Map<Movie, MovieDto>);

这是逻辑:

//for regular API call add N/A to items that are not available
    foreach (MovieDto movie in moviesDto)
    {
        if (movie.NumberAvailable == 0)
                movie.Name = movie.Name + " N/A. :(";
    }
    return Ok(moviesDto);

我在调试模式下在 Foreach 循环中运行时检查电影对象,确实发现某些电影的名称属性附加了“N​​/A :(”。但在视图中,只有电影的 (原始)名称出现。

编辑:在返回给调用者之前检查最后一行的 moviesDto 时,我发现相关电影的名称尚未更新。

FWIW,这是 movieDto 类定义:

public class MovieDto
    {
        public int Id { get; set; }

        [Required]
        [StringLength(100)]
        public string Name { get; set; }

        [Required]
        public byte GenreId { get; set; }

        public GenreDto Genre { get; set; }

        public DateTime ReleaseDate { get; set; }

        public DateTime DateAdded { get; set; }

        [Range(1, 25)]
        public byte NumberInStock { get; set; }

        public byte NumberAvailable { get; set; }
    }
4

1 回答 1

4

您的问题源于使用IEnumerable(由于 LINQ deferred execution)并且是由于您的moviesDto对象实际上是 LINQ 查询这一事实引起的。

每次moviesDto枚举时,都会再次执行查询并从源中提取对象(每次将您的物化实体再次映射到新的 DTO)。

要解决此问题,只需在操作之前将您的集合转换为列表:

var moviesDto = moviesQuery.ToList()
        .Select(Mapper.Map<Movie, MovieDto>).ToList();
于 2017-05-08T21:19:35.093 回答