企业项目实战|企业项目实战 .Net Core + Vue/Angular 分库分表日志系统五 | 完善业务自动创建数据库
教程预览
01 | 前言
02 | 简单的分库分表设计
03 | 控制反转搭配简单业务
04 | 强化设计方案
05 | 完善业务自动创建数据库
说明
这节来把基础的业务部分完善一下。
因为 IQueryable的问题我们还是先把 IDbRepository 换成 ISqlSugarRepository来使用
private readonly ISqlSugarRepository
AutoMapper 和 Swagger 已经有很好的讲解文章,不做重复讲解。
安装基本使用的包
AutoMapper
AutoMapper.Extensions.Microsoft.DependencyInjection
基本介绍和使用方法参考:https://www.cnblogs.com/laozhang-is-phi/p/9560949.html
Swashbuckle.AspNetCore
基本介绍和使用方法参考:https://www.cnblogs.com/laozhang-is-phi/p/9495624.html
业务代码部分没什么重点讲解的这里大家对着写一下就行
1.在项目目录下新建文件夹 Dtos 来存放我们的Dto实体 新建文件夹 EasyLoggerProjectDto 存放项目部分的Dto
文章图片
public class PagedInput
{
public Int32 PageSize { get;
set;
}
public Int32 PageIndex { get;
set;
}
}
public class PagedResultDto
public class EasyLoggerProjectListDto
{
///
/// 主键
///
public int Id { get;
set;
}
///
/// 名称
///
public string Name { get;
set;
}
///
/// 系统编码
///
public string Code { get;
set;
}
}
public class EasyLoggerProjectInput: PagedInput
{
///
/// 项目名称
///
public string Name { get;
set;
}
///
/// 系统编码
///
public string Code { get;
set;
}}
public class EasyLoggerProjectEditDto
{
///
/// 主键
///
public int? Id { get;
set;
}
///
/// 名称
///
public string Name { get;
set;
}
///
/// 系统编码
///
public string Code { get;
set;
}
}
public class CreateOrUpdateEasyLoggerProjectInput
{
public EasyLoggerProjectEditDto EasyLoggerProject { get;
set;
}
}
2.在项目目录下新建文件夹 AutoMapper 存放我们的配置文件 新建类 EntityToViewModelMappingProfile、ViewModelToEntityMappingProfile 统一继承 Profile 来做Dto的配置
文章图片
public class EntityToViewModelMappingProfile : Profile
{
public EntityToViewModelMappingProfile()
{
CreateMap
public class ViewModelToEntityMappingProfile : Profile
{
public ViewModelToEntityMappingProfile()
{
CreateMap
3.Startup 中记得添加AutoMapper
文章图片
#region AutoMapper
services.AddAutoMapper(typeof(EntityToViewModelMappingProfile), typeof(ViewModelToEntityMappingProfile));
#endregion
4.为了方便调试把Swagger也加上去吧(记得操作完重新生成下项目)
文章图片
文章图片
文章图片
5.调试试验一下
文章图片
文章图片
文章图片
6.完工
到此整个教程中最枯燥的部分我们终于把他完成了。
继续改造我们的项目
不同的ORM 都有自己的生成数据库和表的API 我们把这一部分 处理一下
1,将我们的SqlSugar的依赖注入封装起来
在 EasyLogger.SqlSugarDbStorage 类库下新建SqlSugarDbStorageServiceCollectionExtensions 类
文章图片
public static class SqlSugarDbStorageServiceCollectionExtensions
{
public static IServiceCollection AddSqlSugarDbStorage(this IServiceCollection services,
ISqlSugarSetting defaultDbSetting)
{
if (defaultDbSetting == null)
{
throw new ArgumentNullException(nameof(defaultDbSetting));
}services.AddSingleton
2.然后改一下 Startup
文章图片
#region SqlSugar
// 改造一下把 自己的注入部分封装起来
var defaultDbPath = Path.Combine(PathExtenstions.GetApplicationCurrentPath(), $"{Configuration["EasyLogger:DbName"]}.db");
services.AddSqlSugarDbStorage(new SqlSugarSetting()
{
Name = SqlSugarDbStorageConsts.DefaultProviderName,
ConnectionString = @$"Data Source={defaultDbPath}",
DatabaseType = DbType.Sqlite,
LogExecuting = (sql, pars) =>
{
Console.WriteLine($"sql:{sql}");
}
});
#endregion
3.新建 EasyLogger.Model 类库 记得引用 EasyLogger.DbStorage 把我们的数据库实体迁移进去 顺便把我们的日志实体建立一下
文章图片
public class EasyLoggerRecord : IDbEntity
补: 注意调整一下引用
文章图片
4.在 EasyLogger.DbStorage 类库 新建 IPartitionDbTableFactory 接口 来约束ORM生成数据库
public interface IPartitionDbTableFactory
{
void DbTableCreate(string path, bool isBaseDb);
}
5.老规矩 在 EasyLogger.SqlSugarDbStorage 创建类 SqlSugarPartitionDbTableFactory 实现接口
这部分代码的工作:通过外部传递进来数据库的连接,传递创建基础数据库 还是 日志数据库,如果是日志数据库,就在生成数据库的同时,根据当月天数,创建对应的表结构。
文章图片
public class SqlSugarPartitionDbTableFactory : IPartitionDbTableFactory
{public void DbTableCreate(string path, bool isBaseDb)
{var db = new SqlSugarClient(new ConnectionConfig()
{
ConnectionString = $@"Data Source={path}",
DbType = DbType.Sqlite,
IsAutoCloseConnection = true, // 自动释放数据务,如果存在事务,在事务结束后释放
InitKeyType = InitKeyType.Attribute// 从实体特性中读取主键自增列信息
});
// 生成数据库
// db.Ado.ExecuteCommand($"create dataabse {dbName}");
if (isBaseDb)
{
db.CodeFirst.BackupTable().InitTables
6.将我们 Startup 中 ConfigureServices 创建数据库部分 改造成下面这样。
文章图片
#region 默认创建基础数据库 和时间数据库if (!File.Exists(defaultDbPath))
{
var partition = services.BuildServiceProvider().GetService
7.最后记得不要忘了 在我们封装的SqlSugar的注入类 中 添加我们的注入
文章图片
8.效果
文章图片
文章图片
结尾回顾
这节文章前半部分非常的枯燥非常单纯的业务部分。
重点主要在后半部分
1.我们首先建立将ORM自己的注入部分封装起来。
2.更改实体存放位置,让其公共出来,目的是可以被其他类库访问
3.我们创建生成数据库的接口。
4.SqlSugar 使用自己的创建数据库和生成表的方式 实现该接口。
思考
【企业项目实战|企业项目实战 .Net Core + Vue/Angular 分库分表日志系统五 | 完善业务自动创建数据库】现在来看我们的代码是不是很灵活,新的ORM进来只需要根据我们的约束实现自己的部分
我们切换ORM只要将 Startup 中 SqlSugar 这行代码换掉 就切换完成了。
下一节我们来做动态创建数据库连接,切换数据库查询数据,以及跨表查询数据。
推荐阅读
- 17|17 关山松 第二课作业#公众号项目# D20
- RxJava|RxJava 在Android项目中的使用(一)
- 《机器学习实战》高清中文版PDF英文版PDF+源代码下载
- Hacking|Hacking with iOS: SwiftUI Edition - SnowSeeker 项目(一)
- --木木--|--木木-- 第二课作业#翼丰会(每日一淘6+1实战裂变被动引流# 6+1模式)
- 靠QQ月入上万灰色暴利偏门的项目
- spring|spring boot项目启动websocket
- 2020-07-29《吴军·阅读与写作50讲》24实战才能转化效能
- vuex|vuex 基础结构
- 织网布局,社群营销走进山东玖零落地企业