第一部分: http://www.cnblogs.com/cgzl/p/8478993.htmlhtml
第二部分: http://www.cnblogs.com/cgzl/p/8481825.html面试
因为本文主要是讲VSCode开发等, 因此相关等一些angular/.net core的知识就相对少讲点.数据库
我把需求改一下, 如图:api
因为efcore目前仍是使用中间表来创建多对多的关系, 因此分类标签这个需求就没什么特别的了, 就去掉吧. 还有电视剧分季这个技术上也是重复的, 也删掉.app
目前只剩下电视台和电视剧的维护, 还剩下的知识点是:async
因为CRUD画面作起来比较简单, 我相信你们使用该技术的都会, 因此我直接把我写完的代码传上来. 此时页面的操做效果请看视频:post
这时的代码: this
https://pan.baidu.com/s/1egCmuNT0OxJNwkz0OQ72kAspa
这里面又一个比较常见的问题, 就是.net
上述业务的电视剧的增删改就会出现这种状况:
数据库里面原来有4条数据, 而前台操做完, 删除了第3条数据, 而且增长了一条数据, 其他数据的内容可能有变化.
这种集合类增删改的思路应该是这样的:
1.从传进来的集合找出全部新添加的数据(新添加的数据Id一般并不存在, 这是条件), 放在一个临时的集合, 而后添加到context.
2.从数据库集合找出全部须要删除的数据(有一些id在传进来的集合找不到的就是), 放在一个集合, 而后从conetxt一次性移除.
3.两个集合都有的数据就是只须要修改内容的数据, 更新便可.
下面开始实现这个功能:
首先确保Put方法里, 把电视台下全部的电视剧都读取出来:
接下来, 找到MappingProfile.cs, 使用AutoMapper来实现这个功能.
首先要忽略默认的集合映射:
而后调用AfterMap方法作后期手动处理, 代码的意思大概是这样:
或者, 也能够用Linq作一些重构:
回到画面试一下编辑功能:
而后添加和删除:
查看结果:
OK.
下面, 咱们使用Unit Of Work以及Repository Pattern对项目进行重构:
因为这部分也很简单, 而且也不是这篇文章的重点, 我就直接贴出重构后的代码吧:
Database/TvRepostiory.cs:
using System.Collections.Generic; using System.Threading.Tasks; using Microsoft.EntityFrameworkCore; using Tv.Models; namespace Tv.Database { public class TvRepository : ITvRepostitory { private readonly TvContext context; public TvRepository(TvContext context) { this.context = context; } public async Task<List<TvNetwork>> GetTvNetworksAsync() { return await context.TvNetworks.Include(x => x.TvShows).ToListAsync(); } public async Task<TvNetwork> GetTvNetworkByIdAsync(int id, bool includeRelated = true) { if (includeRelated) { return await context.TvNetworks.Include(x => x.TvShows).SingleOrDefaultAsync(x => x.Id == id); } return await context.TvNetworks.FindAsync(id); } public void AddTvNetwork(TvNetwork model) { context.TvNetworks.Add(model); } public void RemoveTvNetwork(TvNetwork model) { context.TvNetworks.Remove(model); } } }
Database/ITvRepository.cs:
using System.Collections.Generic; using System.Threading.Tasks; using Tv.Models; namespace Tv.Database { public interface ITvRepostitory { Task<List<TvNetwork>> GetTvNetworksAsync(); Task<TvNetwork> GetTvNetworkByIdAsync(int id, bool includeRelated = true); void AddTvNetwork(TvNetwork model); void RemoveTvNetwork(TvNetwork model); } }
Database/UnitOfWork.cs:
using System.Threading.Tasks; namespace Tv.Database { public class UnitOfWork : IUnitOfWork { private readonly TvContext context; public UnitOfWork(TvContext context) { this.context = context; } public async Task SaveAsync() { await context.SaveChangesAsync(); } } }
Database/IUnitOfWork.cs:
using System.Threading.Tasks; namespace Tv.Database { public interface IUnitOfWork { Task SaveAsync(); } }
Startup.cs:
public void ConfigureServices(IServiceCollection services) { services.AddAutoMapper(); // services.AddDbContext<TvContext>(opt => opt.UseSqlServer(Configuration["ConnectionStrings:Default"])); services.AddDbContext<TvContext>(opt => opt.UseSqlServer(Configuration.GetConnectionString("Default"))); services.AddScoped<ITvRepostitory, TvRepository>(); services.AddScoped<IUnitOfWork, UnitOfWork>(); services.AddMvc(); }
TvController.cs:
using System.Collections.Generic; using System.Threading.Tasks; using AutoMapper; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using Tv.Database; using Tv.Models; using Tv.ViewModels; namespace Tv.Controllers { public class TvController : Controller { private readonly ITvRepostitory repostiory; private readonly IUnitOfWork unitOfWork; private readonly IMapper mapper; public TvController(ITvRepostitory repostiory, IUnitOfWork unitOfWork, IMapper mapper) { this.repostiory = repostiory; this.unitOfWork = unitOfWork; this.mapper = mapper; } [HttpGet("api/tvnetworks")] public async Task<IEnumerable<TvNetworkViewModel>> GetTvNetworks() { var models = await repostiory.GetTvNetworksAsync(); var vms = mapper.Map<List<TvNetwork>, List<TvNetworkViewModel>>(models); return vms; } [HttpGet("api/tvnetworks/{id}")] public async Task<IActionResult> Get(int id) { var model = await repostiory.GetTvNetworkByIdAsync(id); var vm = mapper.Map<TvNetwork, TvNetworkViewModel>(model); return Ok(vm); } [HttpPost("api/tvnetworks")] public async Task<IActionResult> Post([FromBody]TvNetworkUpdateViewModel vm) { if (!ModelState.IsValid) { return BadRequest(ModelState); } var model = mapper.Map<TvNetworkUpdateViewModel, TvNetwork>(vm); repostiory.AddTvNetwork(model); await unitOfWork.SaveAsync(); var result = mapper.Map<TvNetwork, TvNetworkViewModel>(model); return Ok(result); } [HttpPut("api/tvnetworks/{id}")] public async Task<IActionResult> Put(int id, [FromBody]TvNetworkUpdateViewModel vm) { if (!ModelState.IsValid) { return BadRequest(ModelState); } var dbModel = await repostiory.GetTvNetworkByIdAsync(id); if (dbModel == null) { return NotFound(); } var model = mapper.Map<TvNetworkUpdateViewModel, TvNetwork>(vm, dbModel); await unitOfWork.SaveAsync(); var result = mapper.Map<TvNetwork, TvNetworkViewModel>(model); return Ok(result); } [HttpDelete("api/tvnetworks/{id}")] public async Task<IActionResult> Delete(int id) { var model = await repostiory.GetTvNetworkByIdAsync(id, includeRelated: false); if (model == null) { return NotFound(); } repostiory.RemoveTvNetwork(model); await unitOfWork.SaveAsync(); return NoContent(); } } }
再操做下画面, 没有任何问题.
今天先写到这, VSCode的开发速度仍是很是快的.
还剩下最后一部分--上传文件.