使用mybatis-generator自动生成mybatis相关代码

对于变化一开始我们总是排斥的,我们总是墨守成规,不愿改变。以至于很长一段时间内我还是宁愿自己写Domain类,自己写Mapping文件。直到有一天我有点腻味了,我想要是有工具能帮我做这事就好了!于是我发现了mybatis-generator。

1. mybatis-generator是什么?

mybatis-generator可以根据数据库表自动生成Domain类、DAO类以及Mapping文件等mybatis构件,节省手动编码的时间做更有意义的事情。

它支持所有的MyBatis版本以及iBatis2.2.0以上的版本。

支持Maven插件。

2. 如何配置

2.1 maven configuration

添加mybatis-generator-maven-plugin,示例中使用的mysql DB。

<build>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.7</version>
                <configuration>
                    <!-- 是否覆盖,true表示会替换生成的JAVA文件,false则不覆盖 -->
                    <overwrite>true</overwrite>
                    <verbose>true</verbose>
                </configuration>
                <dependencies>
                    <!--mysql驱动包-->
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>5.1.45</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>

2.2 resources下增加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>
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressAllComments" value="true"/><!-- 是否取消注释 -->
            <property name="suppressDate" value="true"/> <!-- 是否生成注释代时间戳-->
        </commentGenerator>

        <!-- mysql配置 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/sbia_demo?useUnicode=true&amp;characterEncoding=UTF-8"
                        userId="user"
                        password="password">
            <!-- 针对mysql数据库 -->
            <property name="useInformationSchema" value="true"></property>
        </jdbcConnection>

        <javaTypeResolver >
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>

        <!-- domain 领域模型 -->
        <javaModelGenerator targetPackage="com.tm.sbia.domain" targetProject="../sbia-feature-mybatis/src/main/java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>

        <!-- Mapper XML映射文件 -->
        <sqlMapGenerator targetPackage="mapping"  targetProject="src/main/resources">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>

        <!-- dao 接口 -->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.tm.sbia.dao"  targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>

        <!-- 表 -->
        <table tableName="%" >
            <property name="useActualColumnNames" value="false"/>
            <generatedKey column="id" sqlStatement="Mysql" identity="true" />
        </table>
    </context>
</generatorConfiguration>

3. 执行mybatis-generator

3.1 准备数据库表

创建一张示例表,SQL如下:

CREATE TABLE `demo_user` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `code` varchar(20) NOT NULL DEFAULT '' COMMENT '编码',
  `name` varchar(20) NOT NULL DEFAULT '' COMMENT '名字',
  `birthday` date NOT NULL COMMENT '生日',
  `sex` tinyint(4) NOT NULL COMMENT '性别',
  `demo` varchar(100) DEFAULT NULL COMMENT '备注',
  `create_user` varchar(20) NOT NULL DEFAULT '' COMMENT '创建用户',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `update_user` varchar(20) DEFAULT NULL COMMENT '更新用户',
  `update_time` datetime DEFAULT NULL COMMENT '更新时间',
  `ts` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '时间戳',
  `dr` tinyint(4) NOT NULL DEFAULT '0' COMMENT '逻辑删除标识位。0:未删除;1:已删除',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表';

3.2 执行 mybatis-generator:generate

在这里插入图片描述

3.3 执行结果(自动创建的类)

在这里插入图片描述

参考

MyBatis Generator
Maven下用MyBatis Generator生成文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值