目录
2.1 mapping文件中,提取公共sql,做到sql语句的复用,以下直接上代码
MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。
1 Mybatis反向生成
1.1 反向生成集成步骤
- 引入pom
<!-- mybatis-generator-core 反向生成java代码--> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.5</version> </dependency>
- 添加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
- 添加mbgConfiguration.xml文件,配置生成规则, 位置: resources/spring
-
<?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>
- 编写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(); } } } }
- 运行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 + &