美文网首页
由底向上学Web开发——为什么需要持久层框架?

由底向上学Web开发——为什么需要持久层框架?

作者: Oliver_Le | 来源:发表于2017-01-03 15:04 被阅读324次

    前言###

    任何一种企业级Java Web应用,都离不开数据库操作,也就是数据的存储与获取。特别是对于大量数据的高效操作,在大数据时代下尤其被重视。因此,在利用Java开发企业及应用时,如何提高对数据操作的效率,也就成了开发需要考虑的要素之一。
    而持久层框架,也就是为此应运而生。
    通常来讲,在不使用特定的持久层框架的前提下,Java开发者需要书写大量的重复性代码,并嵌入相关的SQL语句来完成与数据库的交互(主要是基本数据操作业务,如单一数据的CRUD SQL代码,以及JDBC相关的代码)。而使用了特定的持久层框架后,在于数据库连接、交互方面的代码量会显著减少。
    其中的一个较为重要原因原因在于持久层框架完成了"面向对象"到"面向关系"的转换。这使得可以通过直接操作Java对象来完成对数据库中对应数据的操作。


    面向关系面向对象 的差异###

    对于Java学习者,都十分清楚的是Java语言是一种面向对象的语言,那么其特征必然包含了

    • 继承
    • 多态
    • 封装

    等面向对象所应具备的特征。
    而对象间的关系亦是通过类图来完成梳理、建模。

    类图举例

    另一方面,对于目前开发用到的数据库而言,大部分是关系型数据库。对于关系型数据库,是不存在对象这样一个概念的,也就不会有面向对象的特征。
    其中存储的实体对象间的关系更多的是通过表结构来表现。
    关系型数据库中的数据关系是通过E-R(实体-关系图)来梳理、实现。

    E-R图举例

    差异带来的问题###

    那么问题来了,当从一个面向关系的数据库中存取一个面向对象的数据,那么必然会由于一些问题:

    1. 数据粒度不同:面向对象的模型在构建时是基于客观实体的,而面向关系的数据表在构建时则是基于字段的,这样的话,面向对象模型会比面相关系的模型拥有更粗的粒度。
    2. 继承关系的表现:面相关系的模型无法通过“继承”表现出父子类间的关系。那么基于继承的多态特征也无法表现出来。
    3. 对象间关系:关系型模型无法明确地确定面向对象模型间的依赖关系。
    4. 数据导航:同一个对象关系网中,两个对象间的数据导航在两种模型下是不同的。

    造成数据的不匹配。


    持久层框架###

    那么为了解决以上的问题,也就是将面向对象模型和面向关系的模型连接起来,使得Java Programing对象可以和数据库中的数据对应起来,就需要一座连接两种模型的“桥梁”,这座“桥”就是ORM(Object-Relation Mapping,对象关系映射)机制。而将这种机制与提高Java开发数据库效率的目的相结合的产物就是持久层框架。
    通常而言,Java 持久层框架需要完成这样的工作:

    1. 将数据保存到可掉电式存储设备中。
    2. 为了提高操作效率,提供ORM机制,并封装必要的数据操作方法,提供方法接口。
    3. 在前两点基础上,可以提供额外的数据业务,如分页、排序等。

    总结###

    至此,总结一下。
    之所以Java Web开发需要使用持久层框架,目的有三:

    1. 作为基础目的,完成Java编程对数据库数据的操作。
    2. 作为主要目的,提高Java编程对数据库数据操作的效率。
    3. 作为附加目的,通过挑选合适的框架,实现所需要的其他数据业务,便与开发。

    相关文章

      网友评论

          本文标题:由底向上学Web开发——为什么需要持久层框架?

          本文链接:https://www.haomeiwen.com/subject/vpigvttx.html