轉自:http://maimode.iteye.com/blog/1539983/java
若是你使用過hibernate的eclipse插件自動建立DAO文件,那麼就容易理解下面介紹的內容;若是你尚未用過hibernate也無妨。下面介紹使用mybatis 3的eclipse插件自動生成相關文件以及如何使用這些文件。sql
eclipse插件安裝地址:http://mybatis.googlecode.com/svn/sub-projects/generator/trunk/eclipse/UpdateSite/數據庫
附件有link安裝包,link安裝方式參考http://maimode.iteye.com/admin/blogs/1164524session
MyBatis Generator詳細介紹參見:http://code.google.com/p/mybatis/wiki/Generatormybatis
安裝插件的過程就不說了,安裝完後,eclipse中File-》new-》other中會發現多了mybatis選項說明插件安裝成功。oracle
![插件安裝成功後new選項中多了mybatis](http://static.javashuo.com/static/loading.gif)
如何使用插件app
在任意項目中利用上圖中的嚮導建立generatorConfig.xml文件(名稱可修改)而後修改文件內容,主要是設置鏈接數據的相關參數:dom
- <?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>
根據名稱應該能纔出來大體的意思。eclipse
配置好鏈接數據庫及表的信息後就能夠利用插件自動生成代碼了。svn
![建立代碼](http://static.javashuo.com/static/loading.gif)
點擊上圖中的選項,若是配置正確,便自動建立相關文件了。
文件主要有三類:
client包,mapper 接口文件
model包,實體bean文件
mapper包,mapper xml文件
如何使用這些自動生成的文件
首先須要將mapper包下的xml文件添加到mybatis的sqlmapper文件中
![](http://static.javashuo.com/static/loading.gif)
而後程序中這樣使用:
- 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);
-
- 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中自定義查詢條件:
![](http://static.javashuo.com/static/loading.gif)
- 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文件。