EF Core基本使用

EF框架

组件下载

特点

1.DBFirst:数据库优先,从数据库生成Class

2.CodeFirst:代码优先,由实体类生成数据库表结构

3.ModelFirst:模型优先,通过数据库可视化设计器设计数据库,同时生成实体类

CodeFirst

  1. 建立数据模型
复制代码
 [Table("AccountInfo")]//定义表名
 public class AccountInfo
 {
     [Key]//主键自增
     public int AccountId { get; set; }
 ​
     public int Name { get; set; }
 ​
     public int Account { get; set; }
 ​
     public int Password { get; set; }
 }

架构缺失

复制代码
 https://json.schemastore.org/appsettings.json

2.appsettings.json中配置连接字符串

复制代码
 {
   "Logging": {
     "LogLevel": {
       "Default": "Information",
       "Microsoft.AspNetCore": "Warning"
     }
   },
   "AllowedHosts": "*",
   "ConnectionStrings": { "ConnStr": "server=LAPTOP-F352TNCB\\SQLEXPRESS;uid=sa;pwd=123456;database=DailyApp" }
 }

3.编写数据库上下文类

复制代码
 /// <summary>
 /// 数据上下文
 /// </summary>
 public class DailyDbContext:DbContext
 {
     public DailyDbContext(DbContextOptions<DailyDbContext> options): base(options)
     {
 ​
     }
 ​
     /// <summary>
     /// 账户
     /// </summary>
     public virtual DbSet<AccountInfo> AccountInfo { get; set; }
 ​
 ​
 }

4.Program中配置注册数据库上下文

复制代码
 builder.Services.AddDbContext<DailyDbContext>(m => m.UseSqlServer(builder.Configuration.GetConnectionString("ConnStr")));

迁移命令

1.点击程序包管理控制台

2.输入两行命令

复制代码
 add-migration liubei
复制代码
 //报错请检查连接字符串是否正确
 update-database

实际运用dbcontext

复制代码
 [Route("api/[controller]/[action]")]
 [ApiController]
 public class AccountController : ControllerBase
 {
     /// <summary>
     /// 数据库上下文
     /// </summary>
     private readonly DailyDbContext db;
 ​
     private readonly IMapper mapper;
 ​
     /// <summary>
     /// 构造函数
     /// </summary>
     /// <param name="db"></param>
     public AccountController(DailyDbContext _db,IMapper _mapper)
     {
         db = _db;
         mapper= _mapper;
     }
 ​
     [HttpPost]
     public IActionResult Reg(AccountinfoDTO accountinfoDTO)
     {
         ApiResponse res=new ApiResponse();
         //业务
         try
         {
             //账号是否存在(没考虑高并发)
             var dbAccount=db.AccountInfo.Where(t => t.Account == accountinfoDTO.Account).FirstOrDefault();
             if (dbAccount != null)
             {
                 res.ResultCode = -1;
                 res.Msg = "对不起,账号被注册";
                 return Ok(res);
             }
             //如果不存在添加账号
             //AccountInfo accountInfo=new AccountInfo() { Name= accountinfoDTO.Name,Account= accountinfoDTO.Account,Password=accountinfoDTO.Password };
             AccountInfo accountInfo =mapper.Map<AccountInfo>(accountinfoDTO);
             db.AccountInfo.Add(accountInfo);
             //保存受影响行数
             int result = db.SaveChanges();
             if (result == 1)
             {
                 res.ResultCode = 1;
                 res.Msg = "注册成功";
             }
             else
             {
                 res.ResultCode = -99;
                 res.Msg = "注册失败";
             }
         }
         catch (Exception)
         {
             res.ResultCode = -99;
             res.Msg = "异常";
         }
         return Ok(res);
     }
 ​
     [HttpGet]
     public IActionResult Login(string account,string password)
     {
         ApiResponse apiResponse = new ApiResponse();
         try
         {
             var dbAccount = db.AccountInfo.Where(t => t.Account == account && t.Password == password).FirstOrDefault();
             if (dbAccount == null)
             {
                 apiResponse.ResultCode = -1;
                 apiResponse.Msg = "登陆失败,账号或密码错误";
                 return Ok(apiResponse);
             }
             apiResponse.ResultCode = 1;
             apiResponse.Msg = "登陆成功";
             apiResponse.ResultData = dbAccount;
             return Ok(apiResponse);
         }
         catch (Exception)
         {
 ​
             apiResponse.ResultCode = -99;
             apiResponse.Msg = "登陆失败,异常";
             return Ok(apiResponse);
         }
   
     }
 }
相关推荐
范纹杉想快点毕业1 小时前
嵌入式 C 语言编程规范个人学习笔记,参考华为《C 语言编程规范》
linux·服务器·数据库·笔记·单片机·嵌入式硬件·fpga开发
诺亚凹凸曼1 小时前
MySQLinnodb引擎普通索引和唯一索引的区别
数据库·mysql
Kyln.Wu1 小时前
【python实用小脚本-187】Python一键批量改PDF文字:拖进来秒出新文件——再也不用Acrobat来回导
python·pdf·c#
hqwest2 小时前
C#WPF实战出真汁01--项目介绍
开发语言·c#·wpf
davawang2 小时前
程序自动化vs人工手动处理
数据库·数据分析·企业文化
xnglan2 小时前
蓝桥杯手算题和杂题简易做法
数据结构·数据库·c++·python·算法·职场和发展·蓝桥杯
小牛壮士3 小时前
Tokenizer(切词器)的不同实现算法
开发语言·算法·c#
天才测试猿3 小时前
接口自动化测试难点:数据库验证解决方案
自动化测试·软件测试·数据库·python·测试工具·职场和发展·接口测试
小云数据库服务专线3 小时前
GaussDB 常用数值类型
数据库·gaussdb
星空下的曙光4 小时前
MySQL → SQL → DDL → 表操作 → 数据类型 知识链整理成一份系统的内容
数据库·sql·mysql