使用mybatis插件generator生成实体类,dao层和mapper映射

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 使用mybatis插件generator生成实体类,dao层和mapper映射

 

 

本文主要讲如何使用generator插件自动生成我们所需要的实体类,Dao层和对应的mapper映射文件,首先讲一下命令行下用本地jar包使用,然后再讲项目中整合进generator插件进行生成。现在教程开始(Mysql数据库为例


一  本地jar包进行自动生成

 

目录结构

所需jar包

配置文件内容

根据本地test数据库中login表自动生成bean,dao,mapper

<?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="C:\Users\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar" />
<context id="DB2Tables" targetRuntime="MyBatis3">  
  <commentGenerator>    
   <property name="suppressDate" value="true"/>
   <property name="javaFileEncoding" value="UTF-8"/>
   <!-- 是否去除自动生成的注释 true:是 : false:否 -->
   <property name="suppressAllComments" value="false"/>  
  </commentGenerator>
  <jdbcConnection driverClass="com.mysql.jdbc.Driver"  
          connectionURL="jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8"
          userId="root"  
          password="root">
  </jdbcConnection>  
  <javaTypeResolver >  
     <property name="forceBigDecimals" value="false" />  
  </javaTypeResolver>  
  <javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="C:\Users\31283\Desktop\generator">
      <property name="enableSubPackages" value="true" />  
      <property name="trimStrings" value="true" />  
  </javaModelGenerator>    
  <sqlMapGenerator targetPackage="mapper"  targetProject="C:\Users\31283\Desktop\generator\">
       <property name="enableSubPackages" value="true" />
  </sqlMapGenerator>     
  <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql"  targetProject="C:\Users\31283\Desktop\generator\">
    <property name="enableSubPackages" value="true" />  
  </javaClientGenerator>  
      <table  tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
</context>  
   
</generatorConfiguration>

需要修改的地方

 本地jar包路径

<classPathEntry location="C:\Users\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar" />
<context id="DB2Tables" targetRuntime="MyBatis3">  
  <commentGenerator>    
   <property name="suppressDate" value="true"/>
   <property name="javaFileEncoding" value="UTF-8"/>
   <!-- 是否去除自动生成的注释 true:是 : false:否 -->
   <property name="suppressAllComments" value="false"/>  
  </commentGenerator>

 数据库连接地址

<jdbcConnection driverClass="com.mysql.jdbc.Driver"  
          connectionURL="jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8"
          userId="root"  
          password="root">
  </jdbcConnection>

 connectionURL:数据库连接地址

 userId:”数据库连接用户名

 password: 数据库连接用户密码

 

对应实体类路径

<javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="C:\Users\31283\Desktop\generator">
      <property name="enableSubPackages" value="true" />  
      <property name="trimStrings" value="true" />  
  </javaModelGenerator>

 targetPackage:实体类要存在com.example.demo.bean.mysql包下面

 targetProject:com.example.demo.bean.mysql包结构在C:\Users\31283\Desktop\generator目录下面

 

 对应mapper文件路径

<sqlMapGenerator targetPackage="mapper"  targetProject="C:\Users\31283\Desktop\generator\">
       <property name="enableSubPackages" value="true" />
  </sqlMapGenerator>

 targetPackage:生成的xml文件存在在mapper目录下面

 targetProject:mapper目录在C:\Users\31283\Desktop\generator下面

 

 对应Dao接口层路径

<javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql"  targetProject="C:\Users\31283\Desktop\generator\">
    <property name="enableSubPackages" value="true" />  
  </javaClientGenerator>

 type:XMLMAPPER

 targetPackage:Dao接口层存在在com.example.demo.dao.mysql目录下面

 targetProject :com.example.demo.dao.mysql包目录在C:\Users\31283\Desktop\generator下面

 

 需要生成表配置项

<table  tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>

 tableName: 数据库表名

 domainObjectName:生成实体类类名

 运行命令

 在C:\Users\31283\Desktop\generator\ 目录下面,也就是我们的配置文件目录下面打开命令行输入一下命令运行即可

 

java -jar .\lib\mybatis-generator-core-1.3.2.jar -configfile .\generator.xml -overwrite

 最终生成目录结构

 

以上就是使用本地jar包的方式使用generator插件自动生成实体类,Dao和mapper的过程

二  Maven项目整合generator插件使用maven命令生成

 1 resources目录下新建generator文件夹

    generator文件夹下面新建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">
<!--使用此插件可以自动根据数据库生成dao,mapper以及bean,,maven命令 mybatis-generator:generate -e  -->
<generatorConfiguration>
    <!-- 数据库驱动:选择你的本地硬盘上面的数据库驱动包-->
    <classPathEntry  location="C:\Users\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar"/>
    <context id="DB2Tables"  targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--数据库链接URL,用户名、密码 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1/test" userId="root" password="root">
        </jdbcConnection>
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>
        <!-- 生成模型的包名和位置-->
        <javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!-- 生成映射文件的包名和位置-->
        <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!-- 生成DAO的包名和位置-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql" targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名-->
        <table tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    </context>
</generatorConfiguration>

 需要修改的地方参照上边本地jar包方式修改即可需要注意的就是实体类,Dao层和mapper文件生成的位置变了,修改如下

targetProject="C:\Users\31283\Desktop\generator"

 改为

targetProject="src/main/java"

 

 maven的pom文件中添加generator插件

 在pom文件中添加以下代码

<plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <configuration>
                    <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
                    <overwrite>true</overwrite>
                    <verbose>true</verbose>
                </configuration>
            </plugin>

使用maven命令运行,maven命令如下

mybatis-generator:generate –e

好了大功告成,以上就是使用本地jar以及maven项目整合插件的方式分别进行实体类,Dao和mapper的生成过程,如有错误多多指教

 

 

 

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
19天前
|
SQL Java 数据库连接
解决mybatis-plus 拦截器不生效--分页插件不生效
本文介绍了在使用 Mybatis-Plus 进行分页查询时遇到的问题及解决方法。依赖包包括 `mybatis-plus-boot-starter`、`mybatis-plus-extension` 等,并给出了正确的分页配置和代码示例。当分页功能失效时,需将 Mybatis-Plus 版本改为 3.5.5 并正确配置拦截器。
134 6
解决mybatis-plus 拦截器不生效--分页插件不生效
|
9天前
|
SQL XML Java
springboot整合mybatis-plus及mybatis-plus分页插件的使用
这篇文章介绍了如何在Spring Boot项目中整合MyBatis-Plus及其分页插件,包括依赖引入、配置文件编写、SQL表创建、Mapper层、Service层、Controller层的创建,以及分页插件的使用和数据展示HTML页面的编写。
springboot整合mybatis-plus及mybatis-plus分页插件的使用
|
2月前
|
SQL Java 数据库连接
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/
文章讲述了在使用Mybatis时遇到的资源文件找不到的问题,并提供了通过修改Maven配置来解决资源文件编译到target目录下的方法。
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/
|
1月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
30 1
|
2月前
|
Java 数据库 Spring
MyBatisPlus分页插件在SpringBoot中的使用
这篇文章介绍了如何在Spring Boot项目中配置和使用MyBatis-Plus的分页插件,包括创建配置类以注册分页拦截器,编写测试类来演示如何进行分页查询,并展示了测试结果和数据库表结构。
MyBatisPlus分页插件在SpringBoot中的使用
|
21天前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
2月前
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
94 1
|
2月前
|
Web App开发 前端开发 关系型数据库
基于SpringBoot+Vue+Redis+Mybatis的商城购物系统 【系统实现+系统源码+答辩PPT】
这篇文章介绍了一个基于SpringBoot+Vue+Redis+Mybatis技术栈开发的商城购物系统,包括系统功能、页面展示、前后端项目结构和核心代码,以及如何获取系统源码和答辩PPT的方法。
|
2月前
|
Java 关系型数据库 MySQL
1、Mybatis-Plus 创建SpringBoot项目
这篇文章是关于如何创建一个SpringBoot项目,包括在`pom.xml`文件中引入依赖、在`application.yml`文件中配置数据库连接,以及加入日志功能的详细步骤和示例代码。