设为首页 收藏本站
查看: 1218|回复: 0

[经验分享] mybatis生成工具MyBatis Generator

[复制链接]

尚未签到

发表于 2016-11-24 03:31:37 | 显示全部楼层 |阅读模式
eclipse插件安装地址:http://mybatis.googlecode.com/svn/sub-projects/generator/trunk/eclipse/UpdateSite/
 
附件有link安装包,link安装方式参考http://maimode.iyunv.com/admin/blogs/1164524
 
MyBatis Generator详细介绍参见:http://code.google.com/p/mybatis/wiki/Generator
 
安装插件的过程就不说了,安装完后,eclipse中File-》new-》other中会发现多了mybatis选项说明插件安装成功。
 
DSC0000.jpg
 
如何使用插件
 
在任意项目中利用上图中的向导创建generatorConfig.xml文件(名称可修改)然后修改文件内容,主要是设置连接数据的相关参数:
参见http://lt200819.iyunv.com/admin/blogs/1888916
 
 
Xml代码   DSC0001.png


  • <?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>  

 
 
根据名称应该能才出来大致的意思。
 
配置好连接数据库及表的信息后就可以利用插件自动生成代码了。
 
DSC0002.jpg
 
点击上图中的选项,如果配置正确,便自动创建相关文件了。
文件主要有三类:
client包,mapper 接口文件
model包,实体bean文件
mapper包,mapper xml文件
 
如何使用这些自动生成的文件
 
首先需要将mapper包下的xml文件添加到mybatis的sqlmapper文件中
 
DSC0003.jpg
 
然后程序中这样使用:
 
 
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中自定义查询条件:
DSC0004.jpg
 
 
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文件。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-304496-1-1.html 上篇帖子: myBatis介绍 下篇帖子: Mybatis用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表