首页 › 程序设计 › java

ibatis自动代码生成工具Abator在Eclipse中的使用

泡在网上的日子 / 文 发表于2012-05-18 10:17 次阅读

对于IBatis应用最烦人的重复工作就是不停的写DAO,DTO,和xml文件里面的sqlmap,其实很多时候这些工作是重复而且无聊的。好在我们还有abator (http://ibatis.apache.org/abator.html ),一个IBatis自动生成工具,他可以帮助你生成大量的DAO,DTO和sqlmap。
如果你使用eclipse作为IDE那么事情就很简单了:

1:ibatis自动代码生成工具Abator可以从这里下载: http://ibatis.apache.org/abator.html

2:将ibatis自动代码生成工具Abator安装到Eclipse中

3:此时可以新建一种文件类型:Abator for iBATIS Configuration File,建立一个

4:在 jdbcConnection 中设置要mapping的数据库的JDBC连接

classPathEntry 是你的JDBC driver类路径

5:javaModelGenerator,sqlMapGenerator,daoGenerator 分别设置 java dataObject、sql mapping文件和 DAO 接口、实现类的生成位置:
targetPackage 目标包,targetProject:Eclipse项目

6:daoGenerator 中可以设置属性:type: ibatis 或 spring 指定生成的dao实现类是使用com.ibatis.dao.client.template.SqlMapDaoTemplate 还是 org.springframework.orm.ibatis.support.SqlMapClientDaoSupport

7: table 中 tableName 指定要处理的表名,可以有多个table

8:table中可以包含子元素 generatedKey: 使Insert方法可以返回值--由指定的column mapping

9:generatedKey中的sqlStatement属性可以是获取sequence的SQL,也可以是获取自增值的SQL

比如:Oracle的 select theSequence.nextVal from dual
SQLServer的 SELECT @@IDENTITY as column_name

10:保存文件,选中文件,右键菜单选择Generate iBATIS Artifacts!

所有的ibatis自动代码生成工具Abator参数都是写在这个根节点中,下面可以用 来生成个自的iBATIS配置文件、Java Bean和DAO
abatorContext的一个属性generatorSet有3个选项Legacy、Java2、Java5

Legacy:如果没有generatorSet属性的话,默认是Legacy。但并不推荐使用Legacy因为它在生成Example类(用于查询条件)的时候有很多限制,他将查询条件写在sqlMap配置文件中,将查询值写在Example中,这样就对修改产生一些困难。

Java2和Java5:他们只支持iBATIS 2.20以上的版本。在以这个模式成生的Example文件中包含了查询条件和查询值。这样修改就方便多了,对于用join的select时的查询就更方 便了,自己可以定义查询条件,自由度高了很多(对于join的and查询可能还得自己修改一下Example代码)。对于or和and的应用Legacy 的限制就比较大了。

描述了JDBC的属性和其jar包的位置.

描述了个自生成的位置。中type属性则用来告诉abator生成的DAO是用于iBATIS还是SPRING等容器。

通过以上步骤,我们就完成了ibatis自动代码生成工具Abator在Eclipse中的安装、配置和使用。


收藏 赞 (0) 踩 (0)
上一篇:Java中ArrayList类的基本用法
1、什么是ArrayList ArrayList就是传说中的动态数组,用MSDN中的说法,就是Array的复杂版本,它提供了如下一些好处: 动态的增加和减少元素 实现了ICollection和IList接口 灵活的设置数组的大小 2、如何使用ArrayList 最简单的例子: ArrayList List = new A
下一篇:Abator自动生成DAO,DTO和sqlMap的使用方法
Abator 能自动生成DAO,DTO和sqlMap,大大提高开发效率。 1.介绍 Abator 是一款iBATIS代码生成工具。它从数据库获取信息,然后产生如下文件。 1)数据库表的SqlMap.xml file 文件,如UserSQL.xml; 2)数据库表的Java Bean Model,如User.java; 3)包含一个综合主