基于SqlSugar的数据库访问处理的封装,支持多数据库并使之适应于实际业务开发中

Python微信订餐小程序课程视频

https://edu.csdn.net/course/detail/36074

Python实战量化交易理财系统

https://edu.csdn.net/course/detail/35475
在我的各种开发框架中,数据访问有的基于微软企业库,有的基于EFCore的实体框架,两者各有其应用场景,不过多的去比较。最近在使用SqlSugar的时候,觉得这个数据访问处理的组件确实很灵活,据说性能也是很不错,于是用来整合测试一下,它对多种关系型数据库如SqlServer、Oracle、Mysql、SQLite、PostgreSQL都很容易提供支持,通过特性标注的方式,可以很好的实现数据访问的处理,这点很类似EfCore的处理,同时SqlSugar又提供很灵活的SQL处理操作。因此多花了一些时间,把SqlSugar的数据访问操作进行一定的封装处理,最后使之适应更广泛的应用。在这个处理过程中,我编写一些单元测试用来测试其相关功能,并编写了几个模块的Winform界面进行测试,效果还是很不错,借此总结分享一下。

1、SQLSugar的相关介绍

SqlSugar是一款 老牌 .NET 开源ORM框架,由果糖大数据科技团队维护和更新 ,使用文档可以参考官方文档:https://www.donet5.com/Home/Doc, GitHub的地址是:https://github.com/donet5/SqlSugar

优点: 简单易用、功能齐全、高性能、轻量级,支持数据库:MySql、SqlServer、Sqlite、Oracle 、 postgresql、达梦、人大金仓。

由于它是ORM的框架组件,因此标识性的处理也是常规的操作,一般的SQLSugar对数据实体对象提供和数据库信息的标注处理。

如对于数据库表的标注:

[**SugarTable**("TB\_DictData")]
public class DictDataInfo
{
}

以及对字段信息主键的标注

        /// 
        /// 编号
 /// 
        [SugarColumn(**IsPrimaryKey** = true)]
 public virtual string ID { get; set; }

或者是自增字段的标注处理

    public class Person 
 {
 //数据库字段
        [SqlSugar.SugarColumn(IsPrimaryKey =true,**IsIdentity** =true)]
 public int Id { get; set; }

而有些字段,和数据库字段是没有对应关系的,可以设置忽略标识,如下所示。

    public class Person 
 {
 //数据库字段
        [SqlSugar.SugarColumn(IsPrimaryKey =true,IsIdentity =true)]
 public int Id { get; set; }

 public int SexId { get; set; }

 //非数据库字段
        [SqlSugar.SugarColumn(**IsIgnore =true**)]
 public string SexName { get; set; }

 .......

定义了这些实体和数据库关系后,我们操作数据库,可以使用 SqlSugarClient 或者 SqlSugarScope 对数据库进行增、删、查、改等功能,SqlSugarClient 和SqlSugarScope 几乎一样,两者差异之处,是后者使用单例(单件)模式,如果我们的对象也是单件模式,就考虑使用SqlSugarScope 对象操作数据库。

例如我们创建一个SqlSugarClient的对象实例,用它来操作数据库获取信息。

var db = new SqlSugarClient(new ConnectionConfig()
{
 DbType = DbType.SqlServer,
 ConnectionString = connectionString,
 InitKeyType = InitKeyType.Attribute,
 IsAutoCloseConnection = true,
 AopEvents = new AopEvents
 {
 OnLogExecuting = (sql, p) =>
 {
 Log.Information(sql);
 Log.Information(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value)));
 }
 }
});

那接下来,我们就可以利用db来进行数据的增删改查处理操作了。

     //查询表的所有
     var list = db.Queryable().ToList();
 
 //插入
 db.Insertable(new Student() { SchoolId = 1, Name = "jack" }).ExecuteCommand();
 
 //更新
 db.Updateable(new Student() { Id = 1, SchoolId = 2, Name = "jack2" }).ExecuteCommand();
 
 //删除
 db.Deleteable().Where(it => it.Id == 1).ExecuteCommand();

一般来说,我们可能倾向于把操作封装为一个函数处理,如下所示

/// 
/// 保存数据到数据库
/// 
/// 
/// 
public async Task<bool> SaveData(LongVoiceResultDto dto)
{
 bool result = false;
 if(dto != null)
 {
 using(var db = CreateDb())
 {
 var info = new ConsultationInfo();
 info.DiscernStatus = dto.taskId;
 info.OperateStatus = "未识别"
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQLSugar是一款轻量级的ORM框架,它提供了一种便捷的方式来访问数据库封装了许多常用的数据库操作方法,简化了开发者的工作量。SQLSugar封装了常见的增删改查操作,通过简单的配置即可连接数据库,并且支持多种数据库类型,例如SQL Server、MySQLSQLite等。 SQLSugar封装使得开发者无需手动编写SQL语句,只需要通过调用框架提供的方法,即可完成数据库操作。这种封装的方式大大提高了开发效率,减少了出错的可能性。同时,SQLSugar还提供了一些高级功能,例如分页查询、事务处理、简单的LINQ语法等,使得开发者能够更灵活和方便地操作数据库SQLSugar封装还带来了良好的可维护性和扩展性。开发者可以将数据库操作代码进行封装,形成独立的数据访问层,可以随时替换底层数据库,而不用改动上层的业务代码。此外,通过使用SQLSugar封装,可以减少代码的冗余和重复,提高了代码的可读性和可维护性。 总之,SQLSugar封装使得数据库操作变得简单、高效和安全。它提供了丰富的功能和灵活的配置选项,可以满足不同场景下的需求。无论是小型项目还是大型企业级应用,使用SQLSugar进行数据库访问都是一个不错的选择。 ### 回答2: SQLSugar是一款轻量级的ORM框架,它提供了一系列封装方法来简化数据库操作。 首先,SQLSugar提供了简单易用的连接数据库的方式。只需要配置连接字符串,就可以轻松地连接到数据库。 其次,SQLSugar封装了常见的数据库操作方法。例如,它提供了ORM方式的查询、插入、更新、删除等操作,可以通过简单的代码实现对数据库的操作。 另外,SQLSugar还提供了对数据库表的创建和删除的封装方法。通过定义实体类和使用数据注解,可以自动创建数据库表,并且可以根据实体类的变化进行表结构的更新。 此外,SQLSugar还提供了事务处理封装。可以通过开启事务,来确保多个数据库操作的原子性和一致性。 最后,SQLSugar还提供了一些高级特性的封装方法。例如,它可以通过Lambda表达式来构建复杂的查询条件,还可以进行分页查询、排序等操作。 总的来说,SQLSugar封装了大部分常见的数据库操作方法,使得开发人员可以更加方便、高效地进行数据库操作。同时,它还提供了一些高级功能的封装,满足了一些特殊需求。无论是初学者还是有经验的开发人员,都可以轻松上手并且使用SQLSugar进行数据库操作。 ### 回答3: SQLSugar是一个基于.NET平台的ORM(Object Relational Mapping)框架,它可以帮助开发者更轻松地访问和操作数据库SQLSugar封装数据库操作的细节,提供了简洁的API,使开发者能够更高效地进行数据库操作。通过SQLSugar开发者无需编写复杂的SQL语句,只需使用简单的代码即可完成数据库的增删改查操作。 SQLSugar支持多种数据库,如SQL Server、MySQL、Oracle等,开发者可以根据项目需求选择适合的数据库类型。SQLSugar提供了一系列常用的方法,如查询、插入、更新、删除等,同时还支持事务操作,保证数据的一致性和完整性。 SQLSugar封装数据库连接的管理,开发者只需简单配置数据库连接字符串,即可连接到相应的数据库SQLSugar支持连接池,提高了数据库连接的复用性和性能。 SQLSugar提供了灵活的查询方式,支持Lambda表达式和Sqlable查询,在查询过程可以根据需要进行条件筛选、排序、分页等操作,使开发者能够更方便地获取所需的数据。 SQLSugar还提供了实体和数据库表之间的映射功能,开发者只需定义实体类和数据库表结构的对应关系,即可实现实体和数据库之间的转换,简化了开发过程。 总之,SQLSugar封装数据库操作的细节,提供了简洁的API,使开发者能够更快速、高效地进行数据库操作。它的优点在于简化了数据库操作代码的编写、提高了开发效率,同时还提供了灵活的查询方式和实体映射功能,满足了不同项目的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值