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. paip.多维理念 输入法的外码输入理论跟文字输出类型精髓

    paip.多维理念 输入法的外码输入理论跟文字输出类型精髓 通常,我们的输入法使用的外码是拼音,但是,这个的用户体验很差.. 应该使用多个外码类型... ##按照词汇来源,有如下几个 固有词ati 来 ...

  2. 为什么说外卖O2O行业的未来在于尖端技术?

    7月13日,百度公司董事长兼CEO李彦宏在发布会上谈及百度外卖时表示,百度外卖里有非常多的人工智能技术的应用,比如同样的商家订单,先配送后配送,时间路线规划等等,都有人工智能的技术,涉及机器学习的问题 ...

  3. javascript基础知识复习一

    JavaScript 一.数据类型 A.String B.Number C.boolean  1.undefined.false.null.0.“”这五个返回的都是false: 2.NAN==NAN返 ...

  4. bind() live()和delegate 区别

    Event bubbling (aka event propagation)冒泡 我们的页面可以理解为一棵DOM树,当我们在叶子结点上做什么事情的时候(如click一个a元素),如果我们不人为的设置s ...

  5. [原创]Java静态代码检查工具介绍

    [原创]Java静态代码检查工具介绍 一  什么是静态代码检查? 静态代码分析是指无需运行被测代码,仅通过分析或检查源程序的语法.结构.过程.接口等来检查程序的正确性,找出代码隐藏的错误和缺陷,如参数 ...

  6. emoji表情引发的JNI崩溃

    今天突然接到客服那边的反馈说,有玩家反馈进游戏后不久就崩溃了,我先是怀疑网络问题,因为一连接聊天成功后就挂了.之后用logcat抓日志,发现挂在jni那里了 JNI DETECTED ERROR IN ...

  7. Visual Studio 2013 and .NET 4.6

    I'm trying to set the 4.6 .NET framework for my project and in the settings, as it wasn't listed, I ...

  8. 内部通信服务Factory(WCF)

    WCF,很好,却又麻烦,很多时候不想用WCF的原因就是:用这个真麻烦... 麻烦的地方,比如: 一堆一堆的服务配置,散落在一个一个的folder下,更新系统时容易出错 客户端除了要知道WCF Cont ...

  9. quick -- 添加按钮

    cc.ui.UIPushButton.new({ normal = "comm_btnGreenBackBack.png", pressed = "comm_btnGre ...

  10. ab测试出现error: connection reset by peer的解决方案

    我们在使用一些开源程序之前,可能会使用ab工具在服务器或者本地进行一次性能评估,但是很多时候却总是会以失败告终,因为,服务器会拒绝你的ab工具发出的http请求, 出现 error: connecti ...