zoukankan      html  css  js  c++  java
  • Mybatis Generator的使用

    在写代码过程中,常常要写一些简单的CURD操作,为了能够把时间用在业务逻辑上,看了Mybatis Generator生成工具,根据官网的文档,改成适合自己使用的生成器。

    mybatis generator的配置文件 如下:

    <?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>
        <!--读取配置文件-->
        <properties resource="generator.properties" />
    
        <context id="MySQLContext" targetRuntime="MyBatis3">
            <!--设置文件编码-->
            <property name="javaFileEncoding" value="UTF-8"/>
    
            <!--配置去掉所有生成的注释-->
            <commentGenerator>
                <property name="suppressAllComments" value="true" />
            </commentGenerator>
    
            <!--设置数据库连接驱动-->
            <jdbcConnection driverClass="${jdbc.driverClass}"
                            connectionURL="${jdbc.url}"
                            userId="${jdbc.username}"
                            password="${jdbc.password}">
            </jdbcConnection>
    
            <!--当字段类型是 DECIMAL或者 NUMERIC时,是否强制转换为BigDecimal,否的话会自动根据规模的大小选择合适的类型  -->
            <javaTypeResolver >
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
    
            <!-- 生成模型的包名和位置-->
            <javaModelGenerator targetPackage="me.xueyao.model" targetProject=".srcmainjava">
                <property name="enableSubPackages" value="true" />
                <property name="trimStrings" value="true" />
            </javaModelGenerator>
    
            <!-- 生成映射文件的包名和位置-->
            <sqlMapGenerator targetPackage="me.xueyao.mapper"  targetProject=".srcmain
    esources">
                <property name="enableSubPackages" value="true" />
            </sqlMapGenerator>
    
            <!-- 生成DAO的包名和位置-->
            <javaClientGenerator type="XMLMAPPER" targetPackage="me.xueyao.mapper"
                                 targetProject=".srcmainjava">
                <property name="enableSubPackages" value="true" />
            </javaClientGenerator>
    
            <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名,需要根据自己的需求修改-->
            <table  tableName="candidate" domainObjectName="Candidate" enableCountByExample="false"
                enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false">
                <generatedKey column="id" sqlStatement="MySql" identity="true" />
            </table>
    
        </context>
    </generatorConfiguration>

    mybatis generator的执行文件 如下:

    package me.xueyao;
    
    import org.mybatis.generator.api.MyBatisGenerator;
    import org.mybatis.generator.config.Configuration;
    import org.mybatis.generator.config.xml.ConfigurationParser;
    import org.mybatis.generator.internal.DefaultShellCallback;
    
    import java.io.InputStream;
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     * @Description: Mybatis Generator 生成器
     * @Author: Simon.Xue
     * @Date: 2019/1/18 13:44
     */
    public class Generator {
    
        public static void main(String[] args) throws Exception {
            //警告信息集合
            List<String> warnings = new ArrayList<String>();
            //读取生成器的配置文件
            InputStream resourceAsStream = Generator.class.getResourceAsStream("/mybatis-generator.xml");
            //创建配置解析器
            ConfigurationParser configurationParser = new ConfigurationParser(warnings);
            //解析配置文件
            Configuration configuration = configurationParser.parseConfiguration(resourceAsStream);
            resourceAsStream.close();
            //true时,如果有相同的文件则覆盖文件
            DefaultShellCallback defaultShellCallback = new DefaultShellCallback(true);
            //创建生成器对象
            MyBatisGenerator myBatisGenerator = new MyBatisGenerator(configuration, defaultShellCallback, warnings);
            //执行生成代码
            myBatisGenerator.generate(null);
            //输出警告信息
            for (String warning : warnings) {
                System.out.println(warning);
            }
        }
    }

    源代码托管在GitHub

  • 相关阅读:
    NHibernate之(12):初探延迟加载机制
    NHibernate之(11):探索多对多关系及其关联查询
    NHibernate之(10):探索父子(一对多)关联查询
    NHibernate之(9):探索父子关系(一对多关系)
    NHibernate之(8):巧用组件之依赖对象
    NHibernate之(7):初探NHibernate中的并发控制
    NHibernate之(5):探索Insert, Update, Delete操作
    NHibernate之(6):探索NHibernate中的事务
    NHibernate之(4):探索查询之条件查询(Criteria Query)
    读写文件
  • 原文地址:https://www.cnblogs.com/twodog/p/12135243.html
Copyright © 2011-2022 走看看