eclipse mybatis Generator

简介: 国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私募机构九鼎控股打造,九鼎投资是在全国股份转让系统挂牌的公众公司,股票代码为430719,为“中国PE第一股”,市值超1000亿元。
国内私募机构九鼎控股打造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选项说明插件安装成功。

 

插件安装成功后new选项中多了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代码   收藏代码
  1. public List<TrackBean> selectTrackOnRoute(String routeName) {  
  2.         List<TrackBean> rt = null;  
  3.         SqlSession session = null;  
  4.         try {  
  5.             session = sqlSessionFactory.openSession();  
  6.             AtfmTrackMapper mapper = session.getMapper(AtfmTrackMapper.class);  
  7.             // 构造查询条件  
  8.             AtfmTrackExample example = new AtfmTrackExample();  
  9.             example.createCriteria()  
  10.             .andRouteIs(routeName);  
  11.             // 查询  
  12.             List<AtfmTrack> list = mapper.selectByExample(example);  
  13.             // 包装成TrackBean  
  14.             rt = this.toTrackBean(list);  
  15.         } catch (Exception e) {  
  16.             e.printStackTrace();  
  17.             logger.error(e.getMessage());  
  18.         } finally {  
  19.             if (session != null)  
  20.                 session.close();  
  21.         }  
  22.         return rt;  
  23.     }  

 

如果where条件比较复杂,还可以自定义查询条件,如上例中andRouteIs(routeName)就是自定义的查询条件。可以在

具体的Example的内部类Criteria中自定义查询条件:

 

 

Java代码   收藏代码
  1. public Criteria andRouteIs(String routeName){  
  2.             StringBuffer sb = new StringBuffer("point_name in " +  
  3.                     "(select p.point from route_point p where p.route = '" + routeName + "') " +  
  4.                     "AND FLIGHT_NO IN " +  
  5.                     "(select D.FLIGHT_NO from syn_aftn_dynamic_recent d " +  
  6.                     "where d.route like '%" + routeName + "%')");  
  7.               
  8.             addCriterion(sb.toString());  
  9.             return this;  
  10.         }  

 

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

 

一旦掌握了插件如何使用,重要的工作就是如何使用XXXExample类了。这种方式,完全不用编写繁琐的mapper xml文件。

目录
相关文章
|
6月前
|
Java 数据库连接 Maven
使用mybatis插件generator生成实体类,dao层和mapper映射
使用mybatis插件generator生成实体类,dao层和mapper映射
360 0
|
6月前
|
Oracle Java 数据库连接
使用Mybatis generator自动生成代码,仅限Oracle数据库
使用Mybatis generator自动生成代码,仅限Oracle数据库
|
XML Java 数据库连接
Mybatis使用generator逆向工程生成器生成entity、mapper、.xml模版类
今天将表建好了,但是一个一个的建实体类、Mapper接口、Mapper.xml文件就十分的麻烦,所以我就想到了MyBatis逆向,今天就操作一把!这里我们采用maven来进行操作。
269 0
|
29天前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
87 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
5月前
|
Java 数据库连接 Android开发
SSM框架——使用MyBatis Generator自动创建代码
SSM框架——使用MyBatis Generator自动创建代码
45 2
|
XML Oracle Java
mybatis generator(MyBatis的逆向工程)
mybatis generator(MyBatis的逆向工程)
127 0
mybatis generator(MyBatis的逆向工程)
不是吧,你还在使用MyBatis Generator?试试这个工具吧
在企业软件开发过程中,大多数时间都是面向数据库表的增删改查开发。通过通用的增删改查代码生成器,可以有效的提高效率,降低成本;把有规则的重复性劳动让机器完成,解放开发人员。
|
Java 数据库连接 数据库
MyBatis逆向工程 Generator
MyBatis逆向工程 Generator
MyBatis逆向工程 Generator
|
Java 数据库连接 Maven
Eclipse中Maven 配置mybatis反向生成代码完整步骤
Eclipse中Maven 配置mybatis反向生成代码完整步骤
272 0
Eclipse中Maven 配置mybatis反向生成代码完整步骤
|
Oracle Java 关系型数据库
一:MyBatis Generator 【SpringMvc+Spring+MyBatis+Maven整合学习笔记】
一:MyBatis Generator 【SpringMvc+Spring+MyBatis+Maven整合学习笔记】
一:MyBatis Generator 【SpringMvc+Spring+MyBatis+Maven整合学习笔记】