……

入坑.net core(三).net core api 3.1 反向工程 增删改查

话接上回:入坑.net core (二) swagger 配置

 

有兴趣的可以看一下,废话不多少,

接下来 教大家怎么用.net core 配置数据库,实现增删改查

 

1.点开VS扩展-》管理扩展

 

 

 搜索 EF

安装EF Core Power Tools工具

 

在这里需要关闭VS工具,安装好再打开当前项目

 

2.右击项目 点击EF Core 工具 选择反向工程

 

 

 

 

 

选择版本,对应当前项目 我的是3.0 

 

 

 

选择表,全选

 

 

 

配置实体和上下文,我这新建了Model类库,可以自行配置

 

 

配置好点确定

 

 

 提示:没有找到Microsoft.EntityFrameworkCore库

管理NuGet程序包,配置

 

 

 

 

再配置以下库

(1)Microsoft.EntityFrameworkCore.SqlServer(连接sql server数据库的包)

(2)Microsoft.EntityFrameworkCore.Tools(命令行所需的库)

(3)Microsoft.EntityFrameworkCore.Design(vs code命令行所需的库,vs2019,不需要安装)

 

 

 

 

 

 

安装版本一定要看仔细

接着配置appsettings.json

 

 

 

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft": "Information",
      "Microsoft.Hosting.Lifetime": "Information"
    }
  },
  "AllowedHosts": "*",
  "ConnectionStrings": {
    "SQLServerConnection": "Data Source=.;Initial Catalog=vuetest;Integrated Security=True"

  }
}

配置:Startup.cs

 

 

 

            //连接sqlserver
            services.AddDbContext<vuetestContext>(options =>
            {
                options.UseSqlServer(Configuration.GetConnectionString("SQLServerConnection"));

            });

 

 

 

 

 

 

最后我们添加API控制器 放增删改查

 

 

 

using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Model;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace Web_API.Controllers
{
    //路由设置
    [Route("api/[controller]")]
    [ApiController]
    public class UserController : ControllerBase
    {
        private readonly vuetestContext _context;
        /// <summary>
        /// 初次判断
        /// </summary>
        /// <param name="context"></param>
        public UserController(vuetestContext context)
        {
            _context = context;
            if (_context.User.Count() == 0)
            {
                _context.User.Add(new User { UserName = "admin", PassWord = "0837EB79BC250163", UserType = 0, Status = 0, Del = 0 });
                _context.SaveChanges();
            }
        }

        /// <summary>
        /// 异步获取
        /// </summary>
        /// <returns></returns>
        [HttpGet]

        public async Task<IActionResult> GetUser()
        {
            //ToListAsync在命名空间 using Microsoft.EntityFrameworkCore;
            return Ok(await _context.User.ToListAsync());
        }

        /// <summary>
        /// 查询
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        [HttpGet("{id}")]
        public async Task<ActionResult<User>> GetUser(int id)
        {
            var todoItem = await _context.User.FindAsync(id);
            if (todoItem == null)
            {
                return NotFound();
            }
            return todoItem;
        }
        /// <summary>
        /// 添加
        /// </summary>
        /// <param name="item"></param>
        /// <returns></returns>
        [HttpPost]
        public async Task<ActionResult<User>> PostUser(User item)
        {
            _context.User.Add(item);
            await _context.SaveChangesAsync();
            return CreatedAtAction(nameof(GetUser), new { id = item.Id }, item);
        }

        /// <summary>
        /// 修改
        /// </summary>
        /// <param name="id"></param>
        /// <param name="item"></param>
        /// <returns></returns>
        [HttpPut("{id}")]
        public async Task<IActionResult> PutUser(int id, User item)
        {
            if (id != item.Id)
            {
                return BadRequest();
            }
            _context.Entry(item).State = EntityState.Modified;
            await _context.SaveChangesAsync();
            return NoContent();
        }
        /// <summary>
        /// 删除
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        [HttpDelete("{id}")]
        public async Task<IActionResult> DeleteUser(int id)
        {
            var todoItem = await _context.User.FindAsync(id);
            if (todoItem == null)
            {
                return NotFound();
            }
            _context.User.Remove(todoItem);
            await _context.SaveChangesAsync();
            return NoContent();
        }
    }
}

  

现在可以直接运行cor API了

控制台运行方法

打开本地根目录

 

 

 输入 dotnet run 运行项目

 

 

 

 

在浏览器输入项目运行地址

 

 

运行接口,就可以实时监控运行效果

 

 

 

到此就结束了,

谢谢各位大爷。

 

成长的道路永远不会一番风顺的,每天成长一点点,加油。

 

先溜为敬。

 

posted @ 2022-05-20 20:40  蟾宝  阅读(411)  评论(0编辑  收藏  举报