Mybatis反向生成及Mybatis实践总结

目录

1 Mybatis反向生成

1.1 反向生成集成步骤

1.2 实践总结

2 Mybatis实践经验

2.1 mapping文件中,提取公共sql,做到sql语句的复用,以下直接上代码

2.2 Mybatis 入参类型总结

2.3 Mybatis返回类型总结

2.4 保存时如果将主键回填至对象

2.5 新增,更新和删除时返回受影响行数? Match数?

2.6 Mybatis 缓存问题

2.7 Mybatis高级映射


123

MyBatis是一个支持普通SQL查询存储过程高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。


1 Mybatis反向生成

1.1 反向生成集成步骤

  1. 引入pom
    <!-- mybatis-generator-core 反向生成java代码-->
            <dependency>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-core</artifactId>
                <version>1.3.5</version>
            </dependency>
  2. 添加jdbc.properties配置数据库信息,位置: resources/config
    validationQuery=SELECT 1
    
    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://url/database_name?useUnicode=true&characterEncoding=utf8&tinyInt1isBit=false
    jdbc.username=test
    jdbc.password=***************
    #定义初始连接数
    initialSize=0  
    #定义最大连接数
    maxActive=20  
    #定义最大空闲
    maxIdle=20  
    #定义最小空闲
    minIdle=1  
    #定义最长等待时间
    maxWait=60000
  3. 添加mbgConfiguration.xml文件,配置生成规则, 位置: resources/spring
  4. <?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">
    <!-- 第一种mybatis逆向生成xml配置 -->
    <generatorConfiguration>
        <properties resource="config/jdbc.properties" />
        <context id="sqlserverTables" targetRuntime="MyBatis3">
            <!-- 生成的pojo,将implements Serializable-->
            <plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
            <commentGenerator>
                <property name="suppressDate" value="true"/>
                <!-- 是否去除自动生成的注释 true:是 : false:否 -->
                <property name="suppressAllComments" value="true" />
            </commentGenerator>
    
            <!-- 数据库链接URL、用户名、密码 -->
            <jdbcConnection driverClass="${jdbc.driver}"
                            connectionURL="${jdbc.url}"
                            userId="${jdbc.username}"
                            password="${jdbc.password}">
            </jdbcConnection>
    
            <!--
            默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer
                true,把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal
            -->
            <javaTypeResolver>
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
    
            <!--
            生成model模型,对应的包路径,以及文件存放路径(targetProject),targetProject可以指定具体的路径,如./src/main/java,
            也可以使用“MAVEN”来自动生成,这样生成的代码会在target/generatord-source目录下
            -->
            <!--<javaModelGenerator targetPackage="com.joey.mybaties.test.pojo" targetProject="MAVEN">-->
            <javaModelGenerator targetPackage="com.fc.preferential.tmp.domain" targetProject=".\src\main\java">
                <property name="enableSubPackages" value="true"/>
                <!-- 从数据库返回的值被清理前后的空格  -->
                <property name="trimStrings" value="false" />
            </javaModelGenerator>
    
            <!--对应的mapper.xml文件  -->
            <sqlMapGenerator targetPackage="com.fc.preferential.tmp.mapper"  targetProject=".\src\main\resources">
                <property name="enableSubPackages" value="true"/>
            </sqlMapGenerator>
    
            <!-- 对应的Mapper接口类文件 -->
            <javaClientGenerator type="XMLMAPPER" targetPackage="com.fc.preferential.tmp.mapper" targetProject=".\src\main\java">
                <property name="enableSubPackages" value="true"/>
            </javaClientGenerator>
    
    
            <!-- 列出要生成代码的所有表,这里配置的是不生成Example文件 -->
            <table tableName="auth_apply_notice" domainObjectName="AuthApplyNotice"
                   enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false"
                   enableSelectByExample="false" selectByExampleQueryId="false">
                <property name="useActualColumnNames" value="false"/>
                <!-- 让字段生成特定的java type -->
                <columnOverride column="status" javaType="Integer"/>
                <columnOverride column="user_scope_type" javaType="Integer"/>
                <columnOverride column="use_condition_type" javaType="Integer"/>
                <columnOverride column="goods_scope_type" javaType="Integer"/>
                <columnOverride column="operate_way_condition_type" javaType="Integer"/>
                <columnOverride column="operate_way" javaType="Integer"/>
                <columnOverride column="postage_type" javaType="Integer"/>
                <columnOverride column="ump_type" javaType="Integer"/>
                <columnOverride column="flow_status" javaType="Integer"/>
                <columnOverride column="module_type" javaType="Integer"/>
            </table>
        </context>
    </generatorConfiguration>
  5. 编写main方法执行生成逻辑,位置:com.fc.preferential.GeneratorCode
    package com.fc.preferential;
    
    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.File;
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     * Created by maclstudio on 2018/7/4.
     */
    public class GeneratorCode {
        public static void main(String[] args) {
        {
            List<String> warnings = new ArrayList<String>();
            boolean overwrite = true;
            //如果这里出现空指针,直接写绝对路径即可。
            String genCfg = "/spring/mbgConfiguration.xml";
            File configFile = new File(GeneratorCode.class.getResource(genCfg).getFile());
            ConfigurationParser cp = new ConfigurationParser(warnings);
            Configuration config = null;
            try {
                config = cp.parseConfiguration(configFile);
            } catch (Exception e) {
                e.printStackTrace();
            }
            DefaultShellCallback callback = new DefaultShellCallback(overwrite);
            MyBatisGenerator myBatisGenerator = null;
            try {
                myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                myBatisGenerator.generate(null);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    
        }
    }
    

     

  6. 运行java程序,生成相应Dao, Module, Mapping文件

1.2 实践总结

  • 怎么控制字段类型,改变框架默认的生成规则?
 <!--
        默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer
            true,把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal
        -->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
  • tinyint(1) 默认生成byte, 怎么改成其生成规则,使其生成Integer类型?以下配置在<table/>标签中

 <!-- 让字段生成特定的java type -->
 <columnOverride column="status" javaType="Integer"/>
 <columnOverride column="user_scope_type" javaType="Integer"/>
 <columnOverride column="use_condition_type" javaType="Integer"/>
  • 字段生成规则控制,一般是数据库设置字段为:create_time, 生成java属性为:createTime, 怎样控制生成驼峰式属性名?
<!-- 此属性设置false, 以此生成驼峰式属性名,否则是和数据库字段名保持一致 -->
<property name="useActualColumnNames" value="false"/>
  • 怎样让domain生成时,在属性上面将数据库中相应注释生成?

此时,可以自己动手实现注释生成的类,实现相应接口并重写即可,框架已经提供扩展。编写自己的类,使其实现接口:

CommentGenerator

以下是简易实现,位置: com.fc.preferential.vo.MyCommentGenerator

package com.fc.preferential.vo;

import org.mybatis.generator.api.CommentGenerator;
import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.*;
import org.mybatis.generator.api.dom.xml.XmlElement;
import org.mybatis.generator.config.PropertyRegistry;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Properties;

import static org.mybatis.generator.internal.util.StringUtility.isTrue;

/**
 * Created by chenglong.ma@shuyun.com on 2018/7/18.
 */
public class MyCommentGenerator implements CommentGenerator{
    private Properties properties;
    private boolean suppressAllComments;
    private String currentDateStr;
    private String authorInfo;

    public MyCommentGenerator() {
        super();
        properties = new Properties();
        suppressAllComments = false;
        currentDateStr = (new SimpleDateFormat("yyyy-MM-dd")).format(new Date());
        authorInfo = "/** \n* Created by maclstudio on " + currentDateStr + &
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值