使用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的生成过程,如有错误多多指教
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南