ibatis自动代码生成工具Abator在Eclipse中的使用
对于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中的安装、配置和使用。