html5 code sqlserver,用VSCode开发一个基于asp.net core 2.0/sql server linux(docker)/ng5/bs4的项目(3)...

由于本文主要是讲VSCode开发等, 所以相关等一些angular/.net core的知识就相对少讲点.

我把需求改一下, 如图:

f35f718fb1f549cca1a4d5103238889e.png

由于efcore目前还是使用中间表来建立多对多的关系, 所以分类标签这个需求就没什么特别的了, 就去掉吧. 还有电视剧分季这个技术上也是重复的, 也删掉.

目前只剩下电视台和电视剧的维护, 还剩下的知识点是:

集合的CRUD操作

对项目结构进行整理, 使用Unit Of Work 以及 Repository 模式

上传文件

由于CRUD画面做起来比较简单, 我相信大家使用该技术的都会, 所以我直接把我写完的代码传上来. 此时页面的操作效果请看视频:

这时的代码:

这里面又一个比较常见的问题, 就是

针对集合的增删改:

68ac4b0957fc8507abb5f1da208ac5a5.png

上述业务的电视剧的增删改就会出现这种情况:

b8919a26a4cbbb56696e69aa483b7473.png

数据库里面原来有4条数据, 而前台操作完, 删除了第3条数据, 并且增加了一条数据, 其余数据的内容可能有变化.

这种集合类增删改的思路应该是这样的:

1.从传进来的集合找出所有新添加的数据(新添加的数据Id通常并不存在, 这是条件), 放在一个临时的集合, 然后添加到context.

2.从数据库集合找出所有需要删除的数据(有一些id在传进来的集合找不到的就是), 放在一个集合, 然后从conetxt一次性移除.

3.两个集合都有的数据就是只需要修改内容的数据, 更新即可.

下面开始实现这个功能:

首先确保Put方法里, 把电视台下所有的电视剧都读取出来:

816b71a2079a469d738bd2576379d761.png

接下来, 找到MappingProfile.cs, 使用AutoMapper来实现这个功能.

首先要忽略默认的集合映射:

530601ada8a9f93cdce14bcef70bdb20.png

然后调用AfterMap方法做后期手动处理, 代码的意思大概是这样:

9d0eb6ee7bb30244cc9cd60a788edac2.png

或者, 也可以用Linq做一些重构:

20fdf4d3199e66589fe80fa8b54192e7.png

回到画面试一下编辑功能:

4e13a2b2f3659d02f44dd81f5b02119d.png

然后添加和删除:

b6566ca995621571056c4b80592ce7bf.png

查看结果:

6c68adf76cd77da09611e10271b0b1bb.png

OK.

项目重构

下面, 我们使用Unit Of Work以及Repository Pattern对项目进行重构:

由于这部分也很简单, 并且也不是这篇文章的重点, 我就直接贴出重构后的代码吧:

Database/TvRepostiory.cs:

usingSystem.Collections.Generic;usingSystem.Threading.Tasks;usingMicrosoft.EntityFrameworkCore;usingTv.Models;namespaceTv.Database

{public classTvRepository : ITvRepostitory

{private readonlyTvContext context;publicTvRepository(TvContext context)

{this.context =context;

}public async Task>GetTvNetworksAsync()

{return await context.TvNetworks.Include(x =>x.TvShows).ToListAsync();

}public async Task GetTvNetworkByIdAsync(int id, bool includeRelated = true)

{if(includeRelated)

{return await context.TvNetworks.Include(x => x.TvShows).SingleOrDefaultAsync(x => x.Id ==id);

}return awaitcontext.TvNetworks.FindAsync(id);

}public voidAddTvNetwork(TvNetwork model)

{

context.TvNetworks.Add(model);

}public voidRemoveTvNetwork(TvNetwork model)

{

context.TvNetworks.Remove(model);

}

}

}

Database/ITvRepository.cs:

usingSystem.Collections.Generic;usingSystem.Threading.Tasks;usingTv.Models;namespaceTv.Database

{public interfaceITvRepostitory

{

Task>GetTvNetworksAsync();

Task GetTvNetworkByIdAsync(int id, bool includeRelated = true);voidAddTvNetwork(TvNetwork model);voidRemoveTvNetwork(TvNetwork model);

}

}

Database/UnitOfWork.cs:

usingSystem.Threading.Tasks;namespaceTv.Database

{public classUnitOfWork : IUnitOfWork

{private readonlyTvContext context;publicUnitOfWork(TvContext context)

{this.context =context;

}public asyncTask SaveAsync()

{awaitcontext.SaveChangesAsync();

}

}

}

Database/IUnitOfWork.cs:

usingSystem.Threading.Tasks;namespaceTv.Database

{public interfaceIUnitOfWork

{

Task SaveAsync();

}

}

Startup.cs:

public voidConfigureServices(IServiceCollection services)

{

services.AddAutoMapper();//services.AddDbContext(opt => opt.UseSqlServer(Configuration["ConnectionStrings:Default"]));

services.AddDbContext(opt => opt.UseSqlServer(Configuration.GetConnectionString("Default")));

services.AddScoped();

services.AddScoped();

services.AddMvc();

}

TvController.cs:

usingSystem.Collections.Generic;usingSystem.Threading.Tasks;usingAutoMapper;usingMicrosoft.AspNetCore.Mvc;usingMicrosoft.EntityFrameworkCore;usingTv.Database;usingTv.Models;usingTv.ViewModels;namespaceTv.Controllers

{public classTvController : Controller

{private readonlyITvRepostitory repostiory;private readonlyIUnitOfWork unitOfWork;private readonlyIMapper mapper;publicTvController(ITvRepostitory repostiory, IUnitOfWork unitOfWork, IMapper mapper)

{this.repostiory =repostiory;this.unitOfWork =unitOfWork;this.mapper =mapper;

}

[HttpGet("api/tvnetworks")]public async Task>GetTvNetworks()

{var models = awaitrepostiory.GetTvNetworksAsync();var vms = mapper.Map, List>(models);returnvms;

}

[HttpGet("api/tvnetworks/{id}")]public async Task Get(intid)

{var model = awaitrepostiory.GetTvNetworkByIdAsync(id);var vm = mapper.Map(model);returnOk(vm);

}

[HttpPost("api/tvnetworks")]public async TaskPost([FromBody]TvNetworkUpdateViewModel vm)

{if (!ModelState.IsValid)

{returnBadRequest(ModelState);

}var model = mapper.Map(vm);

repostiory.AddTvNetwork(model);awaitunitOfWork.SaveAsync();var result = mapper.Map(model);returnOk(result);

}

[HttpPut("api/tvnetworks/{id}")]public async Task Put(intid, [FromBody]TvNetworkUpdateViewModel vm)

{if (!ModelState.IsValid)

{returnBadRequest(ModelState);

}var dbModel = awaitrepostiory.GetTvNetworkByIdAsync(id);if (dbModel == null)

{returnNotFound();

}var model = mapper.Map(vm, dbModel);awaitunitOfWork.SaveAsync();var result = mapper.Map(model);returnOk(result);

}

[HttpDelete("api/tvnetworks/{id}")]public async Task Delete(intid)

{var model = await repostiory.GetTvNetworkByIdAsync(id, includeRelated: false);if (model == null)

{returnNotFound();

}

repostiory.RemoveTvNetwork(model);awaitunitOfWork.SaveAsync();returnNoContent();

}

}

}

再操作下画面, 没有任何问题.

今天先写到这, VSCode的开发速度还是非常快的.

还剩下最后一部分--上传文件.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值