mybatis自动生成代码mybatis-generator

AI觉醒者
• 阅读 3909

1. 前言

Mybatis属于半自动ORM,在使用这个框架中,工作量最大的就是书写Mapping的映射文件(***Entity, ***Dao, ***Mapper.xml),由于手动书写很容易出错,我们可以利用Mybatis-Generator来帮我们自动生成文件。
界面模式:https://github.com/whbing/myb...

2. 步骤

使用mybatis-generator生成代码只需要两步:

1.pom中引入插件:

<!-- above are mybatis dependencies and other...-->
<build>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.4</version>
                <configuration>
                    <!--是否将生成过程输出至控制台-->
                    <verbose>true</verbose>
                    <!--是否覆盖:否-->
                    <overwrite>false</overwrite>
                </configuration>
            </plugin>
        </plugins>
    </build>

2.资源目录(resources)下放置generatorConfig.xml文件:

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="/Users/{your_pc}/.m2/repository/mysql/mysql-connector-java/5.1.39/mysql-connector-java-5.1.39.jar" />
    <context id="context1" defaultModelType="hierarchical" targetRuntime="MyBatis3Simple">
        <!-- 为了防止生成的代码中有很多注释,比较难看,加入下面的配置控制  -->
        <!-- 是否去除自动生成的注释 true:是 :false:否 -->
        <commentGenerator >
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--去除注释的配置要放在数据库配置的前面,不然会报错-->
        <!-- 注释end -->
        
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:MySql://localhost/jms3?characterEncoding=UTF-8&amp;allowMultiQueries=true"
            userId="root" password="whb" />
        <javaModelGenerator targetPackage="com.***.domain.entity"
            targetProject="src/main/java" />
        <sqlMapGenerator targetPackage="sqlmap/mysql"
            targetProject="src/main/resources" />
        <javaClientGenerator targetPackage="com.***.dao"
            targetProject="src/main/java" type="XMLMAPPER" />

        <table tableName="capri_task" domainObjectName="TaskEntity"
            enableCountByExample="true" enableUpdateByExample="true"
            enableDeleteByExample="true" enableSelectByExample="true"
            selectByExampleQueryId="false"></table>


        <table tableName="other..." ...some config...></table>

    </context>
</generatorConfiguration>

使用Maven Project插件,双击mybatis-generator:generate即可在对应位置下生成文件。

上述仅仅引入了mybatis-generator插件,其依赖的mysql jar包需要在配置中明确写出。实际上,还可以通过同时引入mybatis-generator依赖和插件,来优化上述配置。详情

3. 配置文件说明

详情

<generatorConfiguration>
    (1)
    <!-- 可以用于加载或者配置文件,使用${propertyKey}
    resource:从classpath开始找,比如*/generatorConfig.properties        
    url:使用URL的绝对路径方式
    注意 两个属性只能选址一个;
    另外,如果使用了mybatis-generator-maven-plugin,那么在pom.xml中定义的properties都可以直接在generatorConfig.xml中使用 -->
    <properties resource="" url="" />
    
    (2)
    <!-- 额外依赖包 如mysql连接包-->
    <classPathEntry location="..."/>
    
   (3)
    <!--
    context:生成一组对象的环境 
    id:必选,上下文id,用于在生成错误时提示
    defaultModelType:指定生成对象的样式
        1,conditional:类似hierarchical;
        2,flat:所有内容(主键,blob)等全部生成在一个对象中;
        3,hierarchical:主键生成一个XXKey对象(key class),Blob等单独生成一个对象,其他简单属性在一个对象中(record class)
    targetRuntime:
        1,MyBatis3:默认的值,生成基于MyBatis3.x以上版本的内容,包括XXXBySample;
        2,MyBatis3Simple:类似MyBatis3,只是不生成XXXBySample;-->
    <context id="context1" defaultModelType="flat">
    
    ...

运行mybatis-generator插件,即可自动生成,即在指定的文件夹下,生成:

*Mapper.java, 
*Mapper.xml, 
Entity

点赞
收藏
评论区
推荐文章
Easter79 Easter79
3年前
springboot2结合mybatis拦截器实现主键自动生成
前言前阵子和朋友聊天,他说他们项目有个需求,要实现主键自动生成,不想每次新增的时候,都手动设置主键。于是我就问他,那你们数据库表设置主键自动递增不就得了。他的回答是他们项目目前的id都是采用雪花算法来生成,因此为了项目稳定性,不会切换id的生成方式。朋友问我有没有什么实现思路,他们公司的orm框架是mybatis,我就建议他说,不然让你老大把m
这可能是目前最全的!java开发手册嵩山版
在这里分享一份mybatis从入门到精通的强力教程,定能够助你一臂之力。Mybatis基本介绍1.ORM和MyBatis1.对象/关系数据库映射(ORM)1.基本映射方式1.流行的ORM框架简介目前流行的编程语言,例如Java、C等,都是面向对象的编程语言;而目前主流的数据库产品,例如Oracle、DB2等,依然是关系数据库。编程语言和底
Stella981 Stella981
3年前
Mybatis Generator使用教程
\MybatisGenerator(MBG)的作用:根据库中的表自动生成dao、mapper映射文件、实体类1、pom中引入依赖<plugins<plugin<groupIdorg.mybatis.generator</groupId<a
Stella981 Stella981
3年前
Spring Boot(六)集成 MyBatis 操作 MySQL 8
一、简介1.1MyBatis介绍MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。1.2MyBatis发展史MyBatis原本是apache的一个开源项目iBatis,2010年这个项目由apache
Stella981 Stella981
3年前
MyBatis基于Maven的入门
主要内容如下: 1.myBatis在maven中的配置 2.myBatis在工程中的config配置文件3.myBatis为Bean和表的映射文件4.myBatis基本的使用 myBatis在maven中的配置,在pom.xml中增加内容       1.增加依赖 ,mybatis的,还有mysql的驱动的
Stella981 Stella981
3年前
Mybatis映射器源码解析
Mybatis映射器映射器是MyBatis最强大的⼯具,也是我们使用MyBatis时⽤得最多的工具,因此熟练掌握它⼗分必要。MyBatis是针对映射器构造的SQL构建的轻量级框架,并且通过配置生成对应的JavaBean返回给调用者,⽽这些配置主要便是映射器,在MyBatis中你可以根据情况定义动态SQL来满足不同场景的需要,它比其他框架
Stella981 Stella981
3年前
SpringBoot2.0 基础案例(10):整合Mybatis框架,集成分页助手插件
一、Mybatis框架1、mybatis简介MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生类型、接口和Java的POJO
Easter79 Easter79
3年前
SpringBoot2.0 基础案例(10):整合Mybatis框架,集成分页助手插件
一、Mybatis框架1、mybatis简介MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生类型、接口和Java的POJO
Stella981 Stella981
3年前
Maven中使用mybatis
1、Mybatis优缺点优点:Mybatis实现了对Dao层的封装,隔离了SQL语句,便于管理,避免了像JDBC那样操作数据集,便于扩展等等。缺点:Mybatis属于?半自动“ORM”,比Hibernate的工作做得要多很多,对象参数传递比较麻烦,没有Hibernate对象操作的概念。2、Mybatis的实现方式Mybat
Stella981 Stella981
3年前
IDEA Java开发常用插件
AlibabaJavaCodingGuidelines阿里巴巴代码规约检测插件,这个大家都懂,代码规范对个人和团队开发来说都很重要。Lombok省去了getset方法的书写,提高开发效率,很实用。MybatisX根据mapper方法生成mapping方法,方便mapping方法查找,使用Mybatis的话,
Stella981 Stella981
3年前
PowerDesigner列名、注释内容互换
在用PowerDesigner时,常常在NAME或Comment中写中文在Code中写英文,Name只会显示给我们看,Code会使用在代码中,但Comment中的文字会保存到数据库TABLE的Description中,有时候我们写好了Name再写一次Comment很麻烦,以下两段代码就可以解决这个问题。在PowerDesigner中PowerDesig