《三层理论篇》二

四、三层之间的联系


依赖:三层之间的关系

数据访问层的类:直接访问数据库,实现对基本记录的增删改查操作。

业务逻辑层的类:用相关的数据访问类,实现用户所需功能。

界面层:部署控件后,调用业务逻辑层的类,实现功能。

图解:



实体类:层之间的数据传输对象

为什么选择实体类作为三层之间的传输对象?

 ORM(对象关系映射)

        Object Relational Mapping,简称ORM,是为了解决面向对象的类,与关系数据库的表之间,存在的不匹配的现象,通过使用描述对象和关系之间映射的元数据,在程序中的类对象,与关系数据库的表之间建立持久的关系,用于在程序中描述数据库表。本质上就是将数据从一种形式转换到另外一种形式。ORM是一个广义的概念,适应于关系数据库与应用程序之间的各类数据转换。


数据库中课程表的转换。 Course表设计视图


可以这样设计类来描述它:

Public Class Course
   
    Dim _courseid As String
    Dim _courseName As String
    Dim _courseCredit As String

    Public Property CourseID() As String
        Get
            Return _courseid
        End Get
        Set(value As String)
            _courseid = value
        End Set
    End Property
    Public Property CourseName() As String
        Get
            Return _courseName
        End Get
        Set(value As String)
            _courseName = value
        End Set
    End Property
    Public Property CourseCredit() As String
        Get
            Return _courseCredit
        End Get
        Set(value As String)
            _courseCredit = value
        End Set
    End Property

End Class

    将表中的每个字段抽取为类的字段(注意类型匹配),并封装成属性,将表抽取为类。这种类就称为实体类。这个抽取过程称为对象关系映射ORM。,我们为数据库的每个表,都设计一个相应的实体类,这样,就相当于对每个表实体,在.NET程序中,都可以通过类对象来应用。在三层中设计中,通常都会用到实体类对象。

 

数据传输过程:


三层和实体类之间的依赖关系


五、三层的优缺点:

优点:

1、可以降低层与层之间的依赖;

2、开发人员可以只关注整个结构中的其中某一层;

3、可以很容易的用新的实现来替换原有层次的实现;

4、利于各层逻辑的复用。

5、增加系统的灵活性,有利于系统的扩展,有利于标准化;

缺点:

1、降低了系统的性能。如果不采用分层式结构,很多业务可以直接造访数据库,以此获取相应的数据,如今却必须通过中间层来完成。

2、有时会导致级联的修改。这种修改尤其体现在自上而下的方向。如果在表示层中需要增加一个功能,为保证其设计符合分层式结构,可能需要在相应的业务逻辑层和数据访问层中都增加相应的代码。

 

总结三层的应用实现对程序分而治之,系统各个层次各司其职。使应用程序更能够适应企业级应用日益增长的复杂度和灵活性的要求,并且通过软件分层的高内聚、低耦合的原则,实现扩展、维护和重用的要求,可以大大提高开发效率。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 9
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值