asp net core中用efcore操作MySql数据库【包括事务回滚】

本文主要是介绍asp net core中用efcore操作MySql数据库【包括事务回滚】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、环境

  • 开发环境:Win11,VisualStudio2022,MySQL Server 8.0,.Net Core7.0

  • 测试
    在这里插入图片描述

二、MySQL和EFCore相关的包

用NuGet包管理器安装
​​​​​​​​​​​​​​在这里插入图片描述

三、数据库中设置

安装好MySQL数据库,做好基础设置,测试数据连接

用数据库管理软件登录:
在这里插入图片描述

四、创建数据库的表

本例只创建两个简单的表。
在这里插入图片描述
在创建一个标,后面用来进行数据库的事务操作。
在这里插入图片描述

五、dbContext的配置

1、配置的思路

在这里插入图片描述

2、DbContext类的实现

(1)公共构造函数和DbSet的定义

public class TodoContext : DbContext
{public TodoContext(DbContextOptions<TodoContext> options) : base(options) { }public DbSet<User> Users { get; set; }public DbSet<UserLog> UserLogs { get; set; }
}

逐行解释:

public class TodoContext : DbContext{}

DbContext 是 Entity Framework Core 中的核心类,用于与数据库进行交互。本例定义了一个DbContext类型的对象TodoContext。

public TodoContext(DbContextOptions<TodoContext> options) : base(options) { }

这是 TodoContext 的构造函数。
它接受一个 DbContextOptions 类型的参数 options。
: base(options) 表示它将这个 options 参数传递给基类(DbContext)的构造函数。
这允许你在创建 TodoContext 实例时配置数据库连接等选项。

public DbSet<User> Users { get; set; }
public DbSet<UserLog> UserLogs { get; set; }

定义了两个表DbSet

(2)DbSet如何绑定(映射)到数据库中的某个表[Table(“DB中表的名字”)]

  • 把Class User绑定到Table user
/// <summary>
/// User类映射到数据库中的哪一个表,映射到user表
/// </summary>
[Table("user")]
public class User
{/// <summary>/// name列【字段】/// </summary>[Key][Column("name")]public string name { get; set; }/// <summary>/// pw列【字段】/// </summary>[Column("pw")]public string pw { get; set; }
}
  • 把Class UserLog绑定到Table userlog
/// <summary>
///  UserLog类映射到数据库中的哪一个表,映射到userlog表
/// </summary>
[Table("userlog")]
public class UserLog
{[Key][Column("logInfo")]public string logInfo { get; set; }
}

3、asp net core中添加服务

var builder = WebApplication.CreateBuilder(args);  
//......//连接字符串
string conStr = "Server=localhost;Database=testdb;Uid=root;Pwd=abcxyz;";  //连接字符串
builder.Services.AddDbContext<TodoContext>(opt => opt.UseMySQL(conStr));       //启用DbContextvar app = builder.Build();

4、数据库的增删插改

  • insert
 //【1】======增加用户======//将信息Add到数据库中var user = new User { name = "ldh2", pw = "123456" };//这里如何获取todocontext对象呢dbContext.Users.Add(user);await dbContext.SaveChangesAsync();
  • update
//【2】======修改用户======
dbContext.Users.Where(x => x.name == "ldh2").First().pw = "pw123456";
await dbContext.SaveChangesAsync();
  • delete
//【3】======删除用户======
var userToDelete = dbContext.Users.Where(x => x.name == "ldh2").FirstOrDefault();
if (userToDelete != null)
{dbContext.Users.Remove(userToDelete);await dbContext.SaveChangesAsync();
}

5、数据库事务的使用

(1)在 users中添加一个item
(2)在userlogs表中添加一个日志信息
两个操作作为一个事务合并提交

using (var transaction = dbContext.Database.BeginTransaction())
{try{//添加一个用户var idx = dbContext.Users.Count();var newUser = new User { name = $"ldh2{idx + 1}", pw = "123456" };dbContext.Users.Add(newUser);//日志文档添加东西var idx2 = dbContext.UserLogs.Count();var newLog = new UserLog { logInfo = $"添加了一个用户:{newUser} -{idx2}" };dbContext.UserLogs.Add(newLog);//提交事务transaction.Commit();}catch (Exception e){transaction.Rollback();}
}

6、事务的失败和回滚

  • 下面添加一个重复key,故意引发异常进行回滚
var name = dbContext.Users.First().name;
var newUser = new User { name = $"{name}", pw = "123456" }; //key重复,引发异常
  • 提交事务,回滚事务
using (var transaction = dbContext.Database.BeginTransaction())
{try{//添加一个用户var name = dbContext.Users.First().name;var newUser = new User { name = $"{name}", pw = "123456" }; //key重复,引发异常dbContext.Users.Add(newUser);//日志文档添加东西var idx2 = dbContext.UserLogs.Count();var newLog = new UserLog { logInfo = $"添加了一个用户:{newUser} -{idx2}" };dbContext.UserLogs.Add(newLog);//提交事务transaction.Commit();}catch (Exception e){        transaction.Rollback();}
}

7、DbContext中的DbSet与ADO.NET的异同

大概在2003~2007年间用过ado.net(暴露年龄了),所以有点迷惑DbSet和ADO.NET到底有什么关系,所以用ai帮我整了一篇差异(尚未人工仔细复核)。
当然,这里是上述 Markdown 表格的字符串格式:

指标特性DbSet (EF Core)ADO.NET
抽象级别高级抽象低级抽象
编程模型对象关系映射 (ORM)数据集、数据表
SQL 查询主要使用 LINQ通常需要手写 SQL
数据映射自动映射到对象需要手动映射
变更跟踪自动跟踪实体变更需要手动管理
性能控制较少的底层控制更细粒度的控制
使用场景快速开发、复杂数据操作需要精细控制和高性能
学习曲线相对较陡相对较缓
数据库独立性较好较差
代码量通常较少通常较多
底层实现基于 ADO.NET直接实现
事务管理简化的 API需要更多手动控制
并发处理内置支持需要手动实现

这篇关于asp net core中用efcore操作MySql数据库【包括事务回滚】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110620

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1