iBATIS接口应用的浅析

开发 后端
iBATIS接口应用向你介绍在实例中,iBATIS接口的绑定,那么希望本文将会对你有所帮助。

iBATIS接口应用的由来,随着Java 5的推广,我们有机会来改善用户体验。其中最重要的是借助Java 5可以消除令人生惑的类型转换,可以消除SQL映射基于字符的调用方式。举例来说,现在在调用SQL映射的时候是这样的:

  1. Employee employee = (Employee)sqlMapper.queryForList("getEmployee"5);  
  2. //...and...  
  3. List employees = sqlMapper.queryForList("listAllEmployees"); 

问题是很明显的。***,上面的两个例子中被映射的语句的名称都是基于字符串的,而这很容易导致错误。这种方式也不会得到IDE工具、编译器的支持和管理。

第二个问题是存在参数和返回值类型安全问题。在***个例子中,谁能保证参数的类型一定是Integer?而谁又能保证您得到的返回值一定是Employee类型呢?这里,编译器也不会给出任何偿错误报告和提示。而只有运行时异常会被抛出。

***,在集合的例子中问题也是相同的。在运行前,您可能会获得Dogs的集合,而不是Employees。

总之,这种方式虽然比JDBC强,但是也让人倍感难受,还是存在改善的空间。

iBATIS接口应用在Java 5中我们可以充分使用范型来规范集合类型。这样,我们不需要进行特殊的配置就可以为集合类型建立一致的API。我们不需要在XML文件中声明类型,不需要 通过字符名称来调用被映射的语句,相反,我们可以充分利用表达好且类型安全的接口类型。没有什么新东西需要学习,只是普通的接口就可以了。

  1. public interface EmployeeMapper   
  2. {    
  3.   Employee getEmployee (int employeeId);    
  4.   List listAllEmployees();  

这就够了!iBATIS来帮我们实现这个接口。

现在我们可以以一种更加简洁和安全的方式来调用被映射的语句了。

  1. Employee emp = empMapper.getEmployee(5);  
  2. //...and...  
  3. List employees = empMapper.listAllEmployees(); 

在上面的调用中没有类型转换、没有字符串,而且参数和返回值的类型是、安全的。额外的代码就是针对接口使用XML或者Java的标识进行配置。最多我们只需要配置SQL语句、需要进行重载的参数或者返回值类型。

接口描述了所需要的一切。

语句的名称(默认情况下与方法的名字一致)

参数类型(如果存在的话)

返回值类型(包括范型集合的元素的类型)

而其中最有趣的就是我们可以基于方法名称这样的约定来生成SQL映射。以后关于配置的章节中将详细讨论这些细节。

iBATIS接口绑定的方法使得诸如Spring这样的框架将映射类注入其他类变得容易,同时也不需要将事务管理的过多细节公开。

那么以上就是iBATIS接口应用方面的简单介绍,希望对你有所帮助。

【编辑推荐】

  1. iBATIS分页源码真相探讨
  2. iBATIS教程之入门浅析
  3. Hibernate与iBATIS的较量浅析
  4. iBATIS实例创建的五大步浅析
  5. iBATIS with MapBean应用浅析
责任编辑:仲衡 来源: 中国IT实验室
相关推荐

2009-07-17 10:32:45

iBATIS MapB

2009-07-16 13:08:09

iBATIS快速创建应

2009-07-22 11:11:39

iBATIS分页实例ObjectDataS

2009-07-21 11:12:00

iBATIS配置

2009-07-15 17:19:31

iBATIS Ecli

2009-07-22 10:03:11

iBATIS Resu

2009-07-16 09:14:26

iBATIS DAO

2009-07-20 18:00:16

iBATIS DAO事

2009-07-15 17:58:07

iBATIS 动态映射

2009-07-22 10:42:59

iBATIS Cach

2009-07-16 10:23:30

iBATIS工作原理

2009-07-22 13:04:41

iBATIS动态查询

2009-07-17 17:05:44

iBATIS缓存cacheModel

2009-07-22 15:21:00

iBATIS SQLM

2009-07-15 16:42:03

iBATIS读写CLO

2009-07-22 09:44:05

iBATIS Para

2009-07-22 15:01:01

iBATIS SQLM

2009-07-22 16:02:14

iBATIS参数

2009-07-17 09:44:40

iBATIS教程

2009-07-15 17:52:10

点赞
收藏

51CTO技术栈公众号