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 = "未识别"