zoukankan      html  css  js  c++  java
  • 学习笔记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上下文管理

  • 相关阅读:
    原创 ios绘制 圆形气泡
    ios 线程安全单例写法
    (转)ios中点击地图控件MKMapView的某点获取该点的经纬度
    使用正则提取url(iOS)
    MAC系统崩溃,使用命令行复制硬盘内容
    UISearchBar控件UI操作
    app发布流程详解
    App Store审核指南(中文版)2010版
    GCD详解
    iOS扫描二维码(系统方法)
  • 原文地址:https://www.cnblogs.com/pylblog/p/7122568.html
Copyright © 2011-2022 走看看