MyBatis从目前最流行的关系数据库访问方法中吸收了大量的优秀特征和思想,并找出其中的协同增效作用。下图展示了MyBatis框架是如何吸收我们在多年使用不同方式进行数据库集成的 开发过程中所学到的知识,并将其中最优秀的思想结合起来,形成这个混合型解决方案的。

接下来的几节将讨论这些不同的数据库访问方法,以及iBATIS从每种方法中汲取的优秀思想。

SQL

MyBatis的核心是SQL。从根本上说,所有的关系数据库都支持SQL,并将它作为与数据库交互的主要方式。SQL是一种简单的、非过程化的语言,用于操纵数据库,其实SQL包含两种语言。

第一种就是数据定义语言(Data Definition Language, DDL),其中包含像CREATE、DROP以 及ALTER这样的语句。这些语句用于定义数据库数据及其设计,包括表(table)、列(column)、 索引(index)、约束(constraint)、过程(procedure)以及外键关系(foreign key relationship)。iBATIS 并不直接支持DDL。虽然许多人的确通过iBATIS成功地执行了DDL,但我们不推荐这样做,因为 DDL通常应该由某个数据库管理小组拥有并控制,应用程序的开发人员无权操纵它。

SQL所包含的第二种语言就是数据操纵语句(Data Manipulation Language,DML)。DML包

括像SELECT、INSERT、UPDATE以及DELETE这样的用于直接操纵数据的语句。最初,SQL被设计 为一种简单得足以让终端用户(end user)可以使用的语言。按照这种设计思想,图像用户界面 就完全不需要了,甚至连应用程序也不需要了。当然,这种情况得回溯到当年那个永远是“黑屏 上闪着光标”的时代了,在那个时代我们才可以对终端用户报以更多的期望。

今非昔比,数据库已经变得太复杂了,不能指望终端用户通过SQL来直接操纵数据库了。你 能想象这样的情况吗:将一大堆SQL语句交给会计部门,然后对他说,“就这些了,查找一下 BSHEET表你就能找到所需要的信息。”这简直是不可能的了。

仅仅SQL本身已经再也不可能作为终端用户的一个有效接口 了,但对于开发人员来说SQL仍 然是一个非常强大的工具。SQL是唯一具有完整的数据库访问功能的方法,所有其他的工具都不 过是该完整功能的一个子集。正是这个原因,MyBatis完全支持SQL,并将它作为关系数据库访问 的主要方式。同时,MyBatis也具有许多其他方法的优点,这些方法包括存储过程和对象/关系映 射工具。

1.老式存储过程

存储过程(stored procedure)也许可以算是为关系数据库编写应用程序的最古老的方式了。 许多遗留系统使用的都是我们现在称为“两层(two-tier)”的设计。“两层设计”包括一个富客户 端界面来直接调用数据库中的存储过程。这些存储过程中可能包含可用于操纵当前数据库的 SQL。除了SQL,这些存储过程还可能含有(通常也的确含有)业务逻辑。与SQL不同,编写这 些存储过程时使用的语言是过程化的,具有像条件语句和迭代语句这样的流程控制语句。事实上, 仅仅使用存储过程就可以创建一个完整的应用程序。许多软件开发商也开发了像Oracle Forms、 PowerBuilder和Visual Basic这样的富客户端工具来支持“两层”的数据库应用程序的开发。

“两层应用程序”的最大问题在于其性能和扩展性。虽然数据库的功能的确非常强大,但它 们往往未必是处理成百上千甚至上百万个用户访问的最佳选择。对于现代Web应用程序来说,对 扩展性的需求并不少见。数据库在并发访问量、硬件资源以及网络套接字等方面的限制,将使得 这种“两层”架构在需要扩大规模时面临失败的危险。此外,“两层应用程序”的部署也是一场 噩梦。除了通常的富客户端部署问题外,复杂的运行时数据库引擎也需要部署到客户端机器上去。

2.现代存储过程

在某些圈子中存储过程仍被认为是三层(three-tier)和八层(N-tier)应用程序(例如Web应 用程序)的最佳实践。但现在存储过程通常被当作来自中层(middle tier)的远程过程调用(remote procedure call, RPC),并且许多性能方面的约束也可以通过建立间接池和数据库资源管理等方式 解决了。在现代的面向对象的应用程序中,存储过程仍然是实现完整的数据访问层的一个行之有 效的设计选择。存储过程在性能方面的确具有优势,因为它们总是能够比任何其他的解决方案更 快地完成数据库中的数据操作。但是,还有比性能更需要关注的问题。

将业务逻辑放在存储过程中通常都被认为是一个糟糕的设计。最主要的原因就在于存储过程 的开发很难符合现代应用程序的架构。它们难以编写、难以测试、同时也难以部署。更糟糕的是, 现代企业中数据库通常由其他的数据库管理小组拥有,并且受到最为严格的变更控制的保护。它 们通常无法快速变更以适应现代软件开发方法学的需要。此外,要用存储过程来实现完整的业务 逻辑,其自身也存在某些限制。如果业务逻辑需要访问其他的系统、资源或用户界面,存储过程 很可能就无法处理所有这些逻辑了。现代应用程序非常复杂,需要更加通用的语言,而不是像存 储过程这样仅仅优化了数据操纵能力的专用语言。为解决这个问题,有些开发商在它们的数据库 引擎中嵌入了像Java这样的更加强大的语言,来编写更加强壮的存储过程。但这其实根本没有解 决问题,它只会使得应用程序与数据库的边界变得更加模糊,并为数据库管理员带来新的负担: 他们现在需要开始担心数据库中的Java和C#了。对于解决问题,这实在是一个错误的工具。

软件开发中经常出现的一个场景就是矫枉过正(overcorrection)。当发现问题时,尝试的第一个解决方案往往是完全相反的方法。这非但没有解决问题,其结果往往是引入等量的完全不同的新问题。例如我们下面要讨论的内联SQL。

系列文章:

MyBatis知多少(1)

MyBatis知多少(2)的更多相关文章

  1. MyBatis知多少(26)MyBatis和Hibernate区别

    iBatis和Hibernate之间有着较大的差异,但两者解决方案很好,因为他们有特定的领域.我个人建议使用MyBatis的,如果: 你想创建自己的SQL,并愿意维持他们. 你的环境是由关系数据模型驱 ...

  2. MyBatis知多少(26)调试

    这是很容易,同时与iBATIS的工作程序进行调试. iBATIS有内置的日志支持,并适用于下列日志库,并在这个顺序搜索他们. Jakarta Commons日志记录(JCL). Log4J JDK 日 ...

  3. MyBatis知多少(25)动态SQL

    使用动态查询是MyBatis一个非常强大的功能.有时你已经改变WHERE子句条件的基础上你的参数对象的状态.在这种情况下的MyBatis提供了一组可以映射语句中使用,以提高SQL语句的重用性和灵活性的 ...

  4. MyBatis知多少(24)存储过程

    使用MyBatis配置来调用存储过程.为了理解这一章,首先需要了解我们是如何在MySQL中创建一个存储过程. 在继续对本节学习之前,可以自行学习MySQL存储过程. 我们已经在MySQL下有EMPLO ...

  5. MyBatis知多少(23)MyBatis结果映射

    resultMap的元素是在MyBatis的最重要和最强大的元素.您可以通过使用MyBatis的结果映射减少高达90%的JDBC编码,在某些情况下,可以让你做JDBC不支持的事情. ResultMap ...

  6. MyBatis知多少(22)MyBatis删除操作

    本节从表中使用MyBatis删除记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT NOT NULL auto_increment, f ...

  7. MyBatis知多少(21)更新操作

    上一章展示了如何使用MyBatis对表进行读取操作.本章将告诉你如何在一个表中使用MyBatis更新记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( ...

  8. MyBatis知多少(20)MyBatis读取操作

    上篇展示了如何使用MyBatis执行创建操作表.本章将告诉你如何使用MyBatis来读取表. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT ...

  9. MyBatis知多少(19)MyBatis操作

    若要使用iBATIS执行的任何CRUD(创建,写入,更新和删除)操作,需要创建一个的POJO(普通Java对象)类对应的表.本课程介绍的对象,将“模式”的数据库表中的行. POJO类必须实现所有执行所 ...

  10. MyBatis知多少(18)MyBatis系统

    小型.简单系统 小型应用程序通常只涉及单个数据库,只有一些相当简单的用户界面和领域模型.它的业务逻辑非常简单,甚至对一些简单的CRUD (Create, Read, Update, Delete:增删 ...

随机推荐

  1. iOS开发---分类和扩展(Categories和Extensions)

      1.分类能够做到的事情主要是:即使在你不知道一个类的源码情况下,向这个类添加扩展的方法.   此外,分类能够保证你的实现类和其他的文件区分开.   1 #import “UIViewControl ...

  2. 详解eNSP下的单臂路由模拟实验配置

    不同VLAN之间的通信可以通过两种方式:单臂路由和三层交换机.其中,单臂路由是通过路由子接口,交换机的某个端口以trunk的方式与路由器的某个端口相连,同时路由器的链接端口配置子接口,配置子接口承载的 ...

  3. (谷歌浏览器等)解决css中点击input输入框时出现外边框方法【outline:medium;】

    问题:在使用谷歌浏览器,360浏览器时,点击input输入框会出现带颜色的外边框,如下图所示:

  4. 在线测试 ssl 安全性

    记录下, https://www.ssllabs.com/index.html

  5. 部分设备在微信内无法播放audio的解决方案

    临时接到一个紧急的需求,一个活动页面,在某台iPhone 5S设备上无法播放音频,其它设备均正常.我接到这个任务时,也是一脸懵逼,试过在audio标签上添加controls属性来显示audio,结果发 ...

  6. Spring 4.3.2下实现http多次断点下载

    其实跟 spring 无关,如果是直接下载资源很多 web sever 不用程序就直接实现了断点. 但我们的应用是 download?url=xxxx 这种方式 下载资源由 download 来负责, ...

  7. 使用LS2J技术在LotusScript中使用Java

    我们可以使用LS2J技术在LotusScript中来调用Java类,下面举例说明: 1.       首先需要在代理的 (Options)部分,添加如下: Uselsx "*javacon& ...

  8. Android 中的AIDL,Parcelable和远程服务

    Android 中的AIDL,Parcelable和远程服务      早期在学习期间便接触到AIDL,当时对此的运用也是一撇而过.只到近日在项目中接触到AIDL,才开始仔细深入.AIDL的作用    ...

  9. Linux下GCC和Makefile实例(从GCC的编译到Makefile的引入) 转

    http://www.crazyant.net/2011/10/29/linux%E4%B8%8Bgcc%E5%92%8Cmakefile%E5%AE%9E%E4%BE%8B%EF%BC%88%E4% ...

  10. cocos2d-x 3.0rc2中读取sqlite文件

    cocos2d-x 3.0rc2中读取sqlite文件的方式,在Android中直接读取软件内的会失败.须要复制到可写的路径下 sqlite3* dbFile = NULL; std::string ...