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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
简介: 使用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的生成过程,如有错误多多指教

 

 

 

相关实践学习
自建数据库迁移到云数据库
本场景将引导您将网站的自建数据库平滑迁移至云数据库RDS。通过使用RDS,您可以获得稳定、可靠和安全的企业级数据库服务,可以更加专注于发展核心业务,无需过多担心数据库的管理和维护。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
8月前
|
SQL XML Java
MyBatis Mapper中使用limit参数的查询问题
总结而言,MyBatis中使用 `limit`参数的查询可以高度定制并且灵活,基于方法签名和XML映射文件的组合来达成多样化的查询需求。通过参数化查询和动态SQL,MyBatis可以有效地处理各种复杂情境下的数据库操作,并且将SQL语句的维护与业务代码的编写相分离,提升代码的可维护性和可阅读性。
724 13
|
9月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
1511 1
Spring boot 使用mybatis generator 自动生成代码插件
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
2578 1
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
513 10
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
930 0
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
706 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
745 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
817 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块