利用MyBatis Generator自动创建代码

[color=red][b]结合Spring使用Mybatis Generator生成的代码[/b][/color][url]http://www.360doc.com/content/11/0131/12/834950_90117757.shtml[/url]

原文地址:[url]http://maimode.iteye.com/blog/1539983[/url]
如果你使用过hibernate的eclipse插件自动创建DAO文件,那么就容易理解下面介绍的内容;如果你还没有用过hibernate也无妨。下面介绍使用mybatis 3的eclipse插件自动生成相关文件以及如何使用这些文件。

eclipse插件安装地址:http://mybatis.googlecode.com/svn/sub-projects/generator/trunk/eclipse/UpdateSite/

附件有link安装包,link安装方式参考http://maimode.iteye.com/admin/blogs/1164524

MyBatis Generator详细介绍参见:http://code.google.com/p/mybatis/wiki/Generator

安装插件的过程就不说了,安装完后,eclipse中File-》new-》other中会发现多了mybatis选项说明插件安装成功。
[img]http://dl.iteye.com/upload/attachment/0068/5954/071a7c05-ade8-3bc0-a311-9e24227b7a55.jpg[/img]


[b]如何使用插件[/b]

在任意项目中利用上图中的向导创建generatorConfig.xml文件(名称可修改)然后修改文件内容,主要是设置连接数据的相关参数:
<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration >
<context id="context1" >
<jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver" connectionURL="jdbc:oracle:thin:@192.168.2.21:1521:ORCL" userId="atfm" password="atfm" />
<javaModelGenerator targetPackage="com.topsci.atfm.persistence.mybatis.model" targetProject="ATFM" />
<sqlMapGenerator targetPackage="com.topsci.atfm.persistence.mybatis.mapper" targetProject="ATFM" ></sqlMapGenerator>
<javaClientGenerator targetPackage="com.topsci.atfm.persistence.mybatis.client" targetProject="ATFM" type="XMLMAPPER" />
<table schema="" tableName="ATFM_ROUTE_CTRL" ></table>
<table tableName="SYN_TRACK_EST" domainObjectName="AtfmTrack"></table>
</context>
</generatorConfiguration>



根据名称应该能才出来大致的意思。

配置好连接数据库及表的信息后就可以利用插件自动生成代码了。
[img]http://dl.iteye.com/upload/attachment/0068/5961/2e1ce6ed-f9d3-3e49-8abd-795d38247397.jpg[/img]


点击上图中的选项,如果配置正确,便自动创建相关文件了。
文件主要有三类:
client包,mapper 接口文件
model包,实体bean文件
mapper包,mapper xml文件

如何使用这些自动生成的文件

首先需要将mapper包下的xml文件添加到mybatis的sqlmapper文件中



然后程序中这样使用:
public List<TrackBean> selectTrackOnRoute(String routeName) {  
List<TrackBean> rt = null;
SqlSession session = null;
try {
session = sqlSessionFactory.openSession();
AtfmTrackMapper mapper = session.getMapper(AtfmTrackMapper.class);
// 构造查询条件
AtfmTrackExample example = new AtfmTrackExample();
example.createCriteria()
.andRouteIs(routeName);
// 查询
List<AtfmTrack> list = mapper.selectByExample(example);
// 包装成TrackBean
rt = this.toTrackBean(list);
} catch (Exception e) {
e.printStackTrace();
logger.error(e.getMessage());
} finally {
if (session != null)
session.close();
}
return rt;
}


如果where条件比较复杂,还可以自定义查询条件,如上例中andRouteIs(routeName)就是自定义的查询条件。可以在
具体的Example的内部类Criteria中自定义查询条件:
public Criteria andRouteIs(String routeName){  
StringBuffer sb = new StringBuffer("point_name in " +
"(select p.point from route_point p where p.route = '" + routeName + "') " +
"AND FLIGHT_NO IN " +
"(select D.FLIGHT_NO from syn_aftn_dynamic_recent d " +
"where d.route like '%" + routeName + "%')");

addCriterion(sb.toString());
return this;
}


我们可能会担心一旦重新执行generate的时候,我们自己编写的代码会不会丢失,不会的,插件不会修改或丢弃我们自己编写的代码。

一旦掌握了插件如何使用,重要的工作就是如何使用XXXExample类了。这种方式,完全不用编写繁琐的mapper xml文件。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值