分享一个 .Net core Console 项目使用 SqlSugar 的详细例子

2024-06-07 00:44

本文主要是介绍分享一个 .Net core Console 项目使用 SqlSugar 的详细例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

image

前言

SqlSugar 是一款老牌的 .NET 开源 ORM 框架,性能高,功能全面,使用简单,支持 .NET FrameWork、.NET Core3.1、.NET5、.NET6、.NET7、.NET8、.NET9 等版本,线上论坛非常活跃,今天给大伙分享一个 .Net core Console 项目使用 SqlSugar 的详细例子。

Step By Step 步骤

  1. 创建一个 .NET Core Console 项目

  2. 安装 SqlSugarCore Nuget 包,当前使用的是

    <PackageReference Include="SqlSugarCore" Version="5.1.4.69" />
    
  3. 在 Program.cs 中注入 SqlSuger(留意注释

    using SqlSugar;ServiceCollection services = new ServiceCollection();// 注入 单例 ISqlSugarClient
    services.AddSingleton<ISqlSugarClient>(s =>
    {SqlSugarScope sqlSugar = new SqlSugarScope(new ConnectionConfig(){DbType = SqlSugar.DbType.MySql,ConnectionString = "server=localhost;port=3306;user=root;password=db123456;database=testdb",IsAutoCloseConnection = true,}, db =>{// 单例参数配置,所有上下文生效,如果不需要可注释掉db.Aop.OnLogExecuting = (sql, pars) =>{// 在日志里打印 sql 语句logger.LogInformation(sql);};});return sqlSugar;
    });
    
  4. 新建数据层文件 DaoUtil.cs,写 CRUD 代码(留意注释

    using SqlSugar;class DaoUtil
    {private readonly ISqlSugarClient db;// 构造方法注入 ISqlSugarClientpublic DaoUtil(ISqlSugarClient db){this.db = db;}/// <summary>/// 增加数据/// </summary>/// <param name="entity"></param>/// <returns></returns>public int InsertData(deviceData entity){var sql = @"INSERT INTO device_data (id,dev_type,dev_code,dev_name,item_name,item_xh,item_value,item_unit,item_alarm_level,deal_flag,create_time,create_by)VALUE (@id,@dev_type,@dev_code,@dev_name,@item_name,@item_xh,@item_value,@item_unit,@item_alarm_level,@deal_flag,@create_time,@create_by)";var parameters = new List<SugarParameter>(){new SugarParameter("@id",entity.id),new SugarParameter("@dev_type",entity.dev_type),new SugarParameter("@dev_code",entity.dev_code),new SugarParameter("@dev_name",entity.dev_name),new SugarParameter("@item_name",entity.item_name),new SugarParameter("@item_xh",entity.item_xh),new SugarParameter("@item_value",entity.item_value),new SugarParameter("@item_unit",entity.item_unit),new SugarParameter("@item_alarm_level",entity.item_alarm_level),new SugarParameter("@deal_flag",entity.deal_flag),new SugarParameter("@create_time",entity.create_time),new SugarParameter("@create_by",entity.create_by)};var result = db.Ado.ExecuteCommand(sql, parameters);return result;}
    }
    
  5. 在 Program.cs 中注入 DaoUtil 类,调用 CRUD 方法

    // 注入 DaoUtil 类
    services.AddScoped<DaoUtil>();// 调用 DaoUtil 的方法
    using (var sp = services.BuildServiceProvider())
    {var demo = sp.GetRequiredService<DaoUtil>();deviceData entity = new deviceData();demo.InsertData(entity);
    }	
    
  6. 运行程序进行测试

结语

  1. SqlSugar 执行原生 SQL 的功能非常强大,如果不用它的 ORM 功能,完全可以当成一个 ADOHelper 使用,是 EF Core 的一个很好的补充,我个人一般就是这么使用的。
  2. SqlSugar 的 ORM 的性能也很不错,如果不喜欢 EF Core,用用 SqlSugar 的 ORM 也不错。
  3. 注意 MySQL 参数在这里用的也是 @name 形式,而不是原生的 ? 符号

附录:完整的 Program.cs 代码

using SqlSugar;ServiceCollection services = new ServiceCollection();// 注入 单例 ISqlSugarClient
services.AddSingleton<ISqlSugarClient>(s =>
{SqlSugarScope sqlSugar = new SqlSugarScope(new ConnectionConfig(){DbType = SqlSugar.DbType.MySql,ConnectionString = "server=localhost;port=3306;user=root;password=db.server!hx@123;database=hospital",IsAutoCloseConnection = true,}, db =>{// 单例参数配置,所有上下文生效,如果不需要可注释掉db.Aop.OnLogExecuting = (sql, pars) =>{// 在日志里打印 sql 语句logger.LogInformation(sql);};});return sqlSugar;
});// 注入 DaoUtil 类
services.AddScoped<DaoUtil>();// 调用 DaoUtil 的方法
using (var sp = services.BuildServiceProvider())
{var demo = sp.GetRequiredService<DaoUtil>();deviceData entity = new deviceData();demo.InsertData(entity);
}	

我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊人生。

都看到这了,求个点赞、关注、在看三连呗,感谢支持。

这篇关于分享一个 .Net core Console 项目使用 SqlSugar 的详细例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem