且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

mybatis generator maven插件自动生成代码__个人记录

更新时间:2022-06-16 21:51:04

本文只是对于mybatis generator maven插件使用的个人记录,作个备忘,同时也希望对进来的人有所帮助!


一.pom文件中引入插件

此处我引用的是1.3.5版本的,主要是1.3.4 版本及以上可以设置Mapper(Dao)后缀 如mapperName="LotteryDao" 

<plugin>  
		 <!-- 
				 用maven mybatis插件
				 如果不在plugin里面添加依赖包得引用的话,会找不到相关得jar包,
				 在plugin外部得jar包,他不会去找到并执行,
				 所以要把plugin运行依赖得jar配置都放在里面 
		  -->
		<groupId>org.mybatis.generator</groupId>  
		<artifactId>mybatis-generator-maven-plugin</artifactId>  
		<version>1.3.5</version>  
		<executions>  
			<execution>  
				<id>Generate MyBatis Artifacts</id>  
				<goals>  
					<goal>generate</goal>  
				</goals>  
			</execution>  
		</executions>  
		<dependencies>  
			<dependency>  
				<groupId>mysql</groupId>  
				<artifactId>mysql-connector-java</artifactId>  
				 <!-- 引用依赖库的版本 -->
				<version>5.1.38</version>  
			</dependency>  
			<dependency>  
				<groupId>org.mybatis.generator</groupId>  
				<artifactId>mybatis-generator-core</artifactId>  
				<version>1.3.5</version>  
			</dependency>  
		</dependencies>  
</plugin>

注意,如果发现报错Plugin execution not covered by lifecycle configuration: 需要在plugins的外层加上pluginManagement标签.


二.添加generatorConfig.xml文件 

在项目中添加Source File 目录src/main/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>  
    <!-- 引入配置文件 -->  
    <properties resource="jdbc.properties"/>  
    
    <!-- 一个数据库一个context -->  
    <context id="infoGuardian">  
        <!-- 注释 -->  
        <commentGenerator >  
            <property name="suppressAllComments" value="true"/><!-- 是否取消注释 -->  
            <property name="suppressDate" value="true" /> <!-- 是否生成注释代时间戳-->  
        </commentGenerator>  
          
        <!-- jdbc连接 -->  
        <jdbcConnection driverClass="${jdbc_driverClassName}"  
            connectionURL="${jdbc_url}" userId="${jdbc_username}"  
            password="${jdbc_password}" />  
          
        <!-- 类型转换 -->  
        <javaTypeResolver>  
            <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->  
            <property name="forceBigDecimals" value="false"/>  
        </javaTypeResolver>  
          
        <!-- 生成实体类地址 -->    
        <javaModelGenerator targetPackage="com.tangdi.production.convenience.domain"  
            targetProject="src/main/java" >  
            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  
            <property name="enableSubPackages" value="false"/>  
            <!-- 是否针对string类型的字段在set的时候进行trim调用 -->  
            <property name="trimStrings" value="true"/>  
        </javaModelGenerator>  
          
        <!-- 生成mapxml文件 -->  
        <sqlMapGenerator targetPackage="convenience-mapper"  
            targetProject="src/main/resources" >  
            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  
            <property name="enableSubPackages" value="false" />  
        </sqlMapGenerator>  
          
        <!-- 生成mapxml对应client,也就是接口dao -->      
        <javaClientGenerator targetPackage="com.tangdi.production.convenience.dao"  
            targetProject="src/main/java" type="XMLMAPPER" >  
            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  
            <property name="enableSubPackages" value="false" />  
        </javaClientGenerator>  
          
        <!-- 配置表信息 
        	1.3.4 版本及以上可以设置Mapper(Dao)后缀 如mapperName="LotteryDao" 
        	tableName为对应的数据库表 domainObjectName是要生成的实体类名 enable*ByExample 是否生成 example类
		-->      
        <table  tableName="convenience_lotteryuser_inf"  domainObjectName="LotteryInf" mapperName="LotteryDao" 
       		enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false"  
            enableUpdateByExample="false">  
            <!-- 忽略列,不生成bean 字段 -->  
<!--             <ignoreColumn column="FRED" />   -->
            <!-- 指定列的java数据类型 -->  
<!--             <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" />  -->
            
        </table>  
    </context>
</generatorConfiguration> 


同样src/main/resources,里面新建jdbc.properties文件,是上个文件generatorConfig.xml引入的数据库连接相关配置,当然此处也可以直接在generatorConfig.xml中填写相关数据库连接信息

jdbc_driverClassName=com.mysql.jdbc.Driver
jdbc_url=jdbc:mysql://127.0.0.1:3306/dev
jdbc_username=dev
jdbc_password=*******


三.右键pom文件,Run As 用maven build --> Goals中输入 mybatis-generator:generate运行即可

mybatis generator maven插件自动生成代码__个人记录mybatis generator maven插件自动生成代码__个人记录

mybatis generator maven插件自动生成代码__个人记录mybatis generator maven插件自动生成代码__个人记录


四.mybatis generator gui界面工具 推荐使用

另外,有网友基于mybatis generator开发了一款界面工具, 本工具可以使你非常容易及快速生成Mybatis的Java POJO文件及数据库Mapping文件。 

地址:https://github.com/astarring/mybatis-generator-gui

经试用,也是非常好用! 一般第一次设置过之后,后面双击表名即可!

mybatis generator maven插件自动生成代码__个人记录mybatis generator maven插件自动生成代码__个人记录