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);
         }
   
     }
 }
相关推荐
rockey6271 小时前
AScript如何实现中文脚本引擎
c#·.net·script·eval·expression·function·动态脚本
科技小花2 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸2 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain2 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希3 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
我是唐青枫3 小时前
C#.NET gRPC 深入解析:Proto 定义、流式调用与服务间通信取舍
开发语言·c#·.net
荒川之神3 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员3 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java3 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
unicrom_深圳市由你创科技4 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#