博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
学习笔记40_项目管理
阅读量:5147 次
发布时间:2019-06-13

本文共 760 字,大约阅读时间需要 2 分钟。

一个解决方案,应该由如下项目构成:

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上下文管理

转载于:https://www.cnblogs.com/pylblog/p/7122568.html

你可能感兴趣的文章
ad logon hour
查看>>
Linux内核态、用户态简介与IntelCPU特权级别--Ring0-3
查看>>
好玩的-记最近玩的几个经典ipad ios游戏
查看>>
tmux的简单快捷键
查看>>
安装 Express
查看>>
Weka中数据挖掘与机器学习系列之基本概念(三)
查看>>
leetcode-Sort List
查看>>
中文词频统计
查看>>
【Linux】ping命令详解
查看>>
Oracle中包的创建
查看>>
关于PHP会话:session和cookie
查看>>
jQuery on(),live(),trigger()
查看>>
treegrid.bootstrap使用说明
查看>>
[Docker]Docker拉取,上传镜像到Harbor仓库
查看>>
导航,头部,CSS基础
查看>>
[USACO 2017 Feb Gold] Tutorial
查看>>
gzip
查看>>
转负二进制(个人模版)
查看>>
LintCode-Backpack
查看>>
查询数据库锁
查看>>