标签:
有了MyBatis,就不再需要编写JDBC代码了。像JDBCT这样的API的确非常强大,但使用起来总不免觉得太过繁琐。代码清单给出了一个使用JDBC的示例。
从这个例子中很容易看出,JDBC API会产生许多额外的开销。尽管如此,每一行代码又都是必不可少的,所以要减少代码量还真不是一件容易的事情。最多也只不过是将其中的一些代码 挪到某个实用方法中,最明显的就是那些关闭资源(如PreparedStatement和 ResultSet)的代码。
其实,如果使用MyBatis,MyBatis在后台也是运行几乎相同的JDBC代码。MyBatis会获取数据 库连接,设置其参数,执行其语句,获取执行结果,并在最后关闭所有的资源。然而,需要自己亲自编写的代码量却大大地减少了。代码清单给出了使用MyBatis运行相同的SQL语句时你需要编写的代码。
MyBatis显然比JDBC要精简得多
<select id="getEmployee" parameterClass="j ava•lang.Integer" resultClass="Employee"> SELECT ID as id, EMPLOYEE_NUMBER as employeeNumber,
FIRST_NAME as firstName, LAST一NAME as lastName, TITLE as title FROM EMPLOYEE WHERE EMPLOYEE_NUMBER = #empNum# </select>
根本无需比较,MyBatis代码明显更加简洁,更容易阅读,因此也更容易维护。稍后会讨论更多关于使用MyBatis的好处。但是现在,你最关心的可能是如何用Java代码运行以上的语句。 如前例所示,运行它仅仅需要一行简单代码:
Employee emp = (Employee) sqlMap.queryForObject("getEmployee",new Integer(5));
无需多说,这行代码会执行相应的SQL语句,设置其参数,并以一个真实的Java对象的形式作为结果返回。SQL语句被“干干净净”地封装在Java代码之外的一个XML文件中。iBATIS负责 管理幕后的所有资源,其运行的实际效果与我们之前在代码清单中所见的JDBC代码示例是完全一样的。
系列文章:
MyBatis知多少(13)MyBatis如何解决数据库的常见问题
标签:
原文地址:http://www.cnblogs.com/Coda/p/4674993.html