您的位置:首页 > 编程语言 > Java开发

eclipse mybatis Generator

2013-11-07 12:25 330 查看
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html
内部邀请码:C8E245J (不写邀请码,没有现金送)
国内私募机构九鼎控股打造,九鼎投资是在全国股份转让系统挂牌的公众公司,股票代码为430719,为“中国PE第一股”,市值超1000亿元。

------------------------------------------------------------------------------------------------------------------------------------------------------------------

如果你使用过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选项说明插件安装成功。



如何使用插件

在任意项目中利用上图中的向导创建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>
<!-- <classPathEntry location="y:\\workspace\pojo\WebContent\WEB-INF\lib\ojdbc14.jar"
/> -->
<classPathEntry
location="e:\\pojo\WebContent\WEB-INF\lib\mysql-connector-java-5.1.26-bin.jar" />
<context id="Oracle" targetRuntime="MyBatis3">
<!-- 开启注释 -->
<commentGenerator>
<property name="suppressAllComments" value="false" />
</commentGenerator>

<!-- 数据库连接 -->
<!-- connectionURL="jdbc:oracle:thin:@127.0.0.1:1521:orcl" userId="orcl"
password="orcl"> -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/test" userId="root"
password="">
</jdbcConnection>

<!--允许数值类型转换成不同类型,否则都映射为BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>

<!-- 模型文件 -->
<javaModelGenerator targetPackage="cn.com.sgcc.model"
targetProject="webserver/src">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>

<!-- XML映射文件 -->
<sqlMapGenerator targetPackage="com.my.xml"
targetProject="webserver/src">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>

<!-- DAO文件(mapper接口) -->
<javaClientGenerator targetPackage="com.my.dao"
targetProject="webserver/src" type="XMLMAPPER">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>

<!-- 数据库表 -->
<!--  <table tableName="T_USER" domainObjectName="User">
<property name="useActualColumnNames" value="false" />-->
<!-- <generatedKey column="ID" sqlStatement="DB2" identity="true" /> <columnOverride
column="DATE_FIELD" property="startDate" /> <ignoreColumn column="FRED" />
<columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
<!-- </table> -->

<table tableName="T_USERDETAIL" domainObjectName="UserDetail">
<!-- useActualColumnNames属性是为了使生成的model字段与数据库的字段大小写不一致 -->
<property name="useActualColumnNames" value="false" />
</table>

</context>
</generatorConfiguration>


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

配置好连接数据库及表的信息后就可以利用插件自动生成代码了。



点击上图中的选项,如果配置正确,便自动创建相关文件了。

文件主要有三类:

client包,mapper 接口文件

model包,实体bean文件

mapper包,mapper xml文件

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

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



然后程序中这样使用:

Java代码


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中自定义查询条件:



Java代码


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文件。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: