学习笔记40_项目管理
一个解决方案,应该由如下项目构成:
1. UI(5)
2.BLL业务逻辑层(4)
3.数据库BLL(数据库防护层,内含数据库工厂)(依赖IDAL,MODEL,DAL)(3)
*如果想更加解耦,应该添加一个项目,用于存放工厂类,以隔离 数据库BLL和数据库DAL
4.数据库MODEL(0)
5.IDAL(数据库访问层接口)(依赖MODEL)(1)
6.DAL(依赖IDAL,MODEL)(2)
**使用
[DAL工厂]
Assembly.Load("程序集DAL").GreateInstance("程序集DAL.数据DAL");
程序集和DAL类,要使用:
public I数据DAL get数据DAL(参数)
{
var 所有程序集;
//根据参数,在所有程序集中,找出对应的,实现了IXXXDAL接口的DAL实例,
往往对DAL的类名,程序集的名字,有严格的要求,
造成其变化点就是程序集的名字
}
***在使用EF来操作数据库的时候,有时业务逻辑要操作多个表,如果一个个表操作都要在
数据库中的BLL来DbContext.SaveChange()的话,要操作多次数据库库,所以应该添加一个
DbSession的项目,此项目用来包裹[DAL工厂]方法,其中,有
public int SaveChanges()
{
//一个请求产生一个DBContext,请求将要结束时执行SaveChanges()
DbContextFactory.GetCurrentDbContext().SaveChange();
}
//如何使得dbContext和当前请求对应起来?看学习笔记34_EF上下文管理
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现