IntelliJ IDEA中使用通用Mapper做逆向工程

情景:

在springboot+通用Mapper 项目中。通用Mapper优化封装了mybatis。但是我之前用mybatis时可以进行逆向工程,生成代码(参见我之前写的文章《IntelliJ IDEA中使用mybatis-generator》)。那么如何用通用Mapper也能做逆向工程,生成代码呢?本文就来简述一下步骤。

条件:

  • 软件:IntelliJ IDEA
  • 项目:maven +通用mapper

我本想尝试用gradle来构建项目,生成代码的。但是苦于不知道如何将通用mapper生成代码插件在build.gradle中使用以及如何来运行这个build.gradle文件。只能放弃,该用maven来构建项目。

步骤:

1、创建maven项目
项目结构.png
2、pom.xml 导入相关依赖

 <project xmlns="[http://maven.apache.org/POM/4.0.0](http://maven.apache.org/POM/4.0.0)" xmlns:xsi="[http://www.w3.org/2001/XMLSchema-instance](http://www.w3.org/2001/XMLSchema-instance)"

xsi:schemaLocation="[http://maven.apache.org/POM/4.0.0](http://maven.apache.org/POM/4.0.0)[http://maven.apache.org/xsd/maven-4.0.0.xsd](http://maven.apache.org/xsd/maven-4.0.0.xsd)">

<modelVersion>4.0.0</modelVersion>

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.5.6.RELEASE</version>

</parent>

<groupId>top.smartpos</groupId>

<artifactId>demo</artifactId>

<version>1.0.0</version>

<properties>

<java.version>1.8</java.version>

<mybatis.version>1.3.1</mybatis.version>

<mapper.version>3.4.3</mapper.version>

<mybatis-generator.version>1.3.3</mybatis-generator.version>

<mybatis-tk.version>1.1.4</mybatis-tk.version>

<pagehelper.version>1.2.1</pagehelper.version>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

<[maven.compiler.source](http://maven.compiler.source/)>1.8</[maven.compiler.source](http://maven.compiler.source/)>

<[maven.compiler.target](http://maven.compiler.target/)>1.8</[maven.compiler.target](http://maven.compiler.target/)>

<!-- Mybatis Generator -->

<!-- >>>>>>>>>>>>>>>>>>>>>>>>>java 接口和实体类 <<<<<<<<<<<<<<<<<<<<<<<-->

<!-- ${basedir}:引用工程根目录-->

<!-- targetJavaProject :声明存放源码的目录位置-->

<targetJavaProject>${basedir}/src/main/java</targetJavaProject>

<!-- targetModelPackage :声明存MBG生成 XxxMapper接口后存放的package位置 -->

<targetMapperPackage>top.smartpos.itom.mappers</targetMapperPackage>

<!--targetModelPackage : 声明MBG生成实体类后存放的package位置 -->

<targetModelPackage>top.smartpos.itom.entity</targetModelPackage>

<!-- >>>>>>>>>>>>>>>>>>>>>>>>>xml 生成路径 <<<<<<<<<<<<<<<<<<<<<<<<-->

<!-- targetResoutcesProject :声明存放资源文件和XML配置文件的目录位置 -->

<targetResoutcesProject>${basedir}/src/main/resources</targetResoutcesProject>

<!-- targetXMLProject 声明存放具体XxxMapper.xml文件的目录位置-->

<!--**注意:这地方路径是/ 而不是 .** -->

<targetXMLProject>top/smartpos/itom/mappers</targetXMLProject>

<!-- 依赖版本-->

<!--通用mapper的版本号-->

<mapper.version>4.0.4</mapper.version>

<!--MYSQL 驱动版本号-->

<mysql.version>5.1.29</mysql.version>

<mybatis.generator.version>1.3.4</mybatis.generator.version>

</properties>

<dependencies>

<!-- SpringBoot - Web -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<!-- SpringBoot - MyBatis -->

<dependency>

<groupId>org.mybatis.spring.boot</groupId>

<artifactId>mybatis-spring-boot-starter</artifactId>

<version>${mybatis.version}</version>

</dependency>

<!-- SpringBoot - MyBatis 逆向工程 -->

<dependency>

<groupId>org.mybatis.generator</groupId>

<artifactId>mybatis-generator-core</artifactId>

<version>${mybatis-generator.version}</version>

</dependency>

<!-- MyBatis 通用 Mapper -->

<dependency>

<groupId>tk.mybatis</groupId>

<artifactId>mapper-spring-boot-starter</artifactId>

<version>${mybatis-tk.version}</version>

</dependency>

<!-- Mysql -->

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

</dependency>

</dependencies>

<build>

<plugins>

<!-- MyBatis 逆向工程 插件 -->

<plugin>

<groupId>org.mybatis.generator</groupId>

<artifactId>mybatis-generator-maven-plugin</artifactId>

<version>1.3.6</version>

<dependencies>

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>${mysql.version}</version>

</dependency>

<dependency>

<groupId>tk.mybatis</groupId>

<artifactId>mapper</artifactId>

<version>${mapper.version}</version>

</dependency>

</dependencies>

<configuration>

<!-- 允许移动生成的文件 -->

<verbose>true</verbose>

<!-- 是否覆盖 -->

<overwrite>true</overwrite>

<!-- 配置文件 -->

<configurationFile>

${basedir}/src/main/resources/generatorConfig.xml

</configurationFile>

</configuration>

</plugin>

</plugins>

</build>

</project>

3、创建属性文件application.properties
 # Generator

generator.targetProject=src/main/java

#通用Mapper插件

generator.plugin=tk.mybatis.mapper.generator.MapperPlugin

# 可以修改自定义的mapper接口

generator.mappers=[tk.mybatis.mapper.common.Mapper](http://tk.mybatis.mapper.common.mapper/)

generator.javaModel-targetPackage=top.smartpos.itom.entity

generator.sqlMap-targetPackage=top.smartpos.itom.mappers

generator.javaClient-targetPackage=top.smartpos.itom.mappers

# 数据库信息

jdbc.driverClass= com.mysql.jdbc.Driver

jdbc.url= jdbc:mysql://localhost:3306/mytest
jdbc.user= root

jdbc.password= root

4、创建gengratorConfig.xml
 <?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE generatorConfiguration

PUBLIC "-//[mybatis.org//DTD](http://mybatis.org//DTD) MyBatis Generator Configuration 1.0//EN"

"[http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd](http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd)">

<generatorConfiguration>

<!-- 引入 application.properties -->

<properties resource="application.properties" />

<!-- MyBatis3Simple:不生成 Example相关类及方法 -->

<context id="Mysql" targetRuntime="MyBatis3Simple" defaultModelType="flat">

<property name="beginningDelimiter" value="`" />

<property name="endingDelimiter" value="`" />

<!-- 指定生成 Mapper 的继承模板 -->

<plugin type="${generator.plugin}">

<property name="mappers" value="${generator.mappers}" />

</plugin>

<!-- 生成 JavaBean 对象重写 toString方法 -->

<plugin type="org.mybatis.generator.plugins.ToStringPlugin" />

<!-- 生成 JavaBean 对象继承 Serializable 类 -->

<plugin type="org.mybatis.generator.plugins.SerializablePlugin" />

<!-- 生成 JavaBean 对象重写 equals 和 hashCode 方法 -->

<!-- <plugin type="org.mybatis.generator.plugins.EqualsHashCodePlugin" /> -->

<!-- jdbc 连接配置 -->

<jdbcConnection driverClass="${jdbc.driverClass}"

connectionURL="${jdbc.url}"

userId="${jdbc.user}"

password="${jdbc.password}">

</jdbcConnection>

<javaModelGenerator targetPackage="${targetModelPackage}"

targetProject="${targetJavaProject}" />

<sqlMapGenerator targetPackage="${targetXMLProject}"

targetProject="${targetResoutcesProject}" />

<javaClientGenerator targetPackage="${targetMapperPackage}"

targetProject="${targetJavaProject}" type="XMLMAPPER" />

<!-- Mysql 配置 -->

<!-- <generatedKey column="id" sqlStatement="Mysql" identity="true" /> -->

<!-- Oracle 配置 -->

<!-- <generatedKey column="id" sqlStatement="select SEQ_{1}.nextval from dual" identity="false" type="pre"/> -->

<!-- tableName:数据库表名,domainObjectName:生成文件名 ,schema:数据源-->

<table tableName="emp_info" domainObjectName="EmpInfo">

<generatedKey column="e_id" sqlStatement="Mysql" identity="true" />

</table>

</context>

</generatorConfiguration>

注意:

1、需要把 application.properties 和 pom.xml 出现的文件目录都手动创建出来。
2、在gengratorConfig.xml 引入 application.properties 文件,可以使用其中已经定义好的变量。同时gengratorConfig.xml 文件可以直接使用pom.xml文件定义的变量。

5、运行

运行maven 中pom.xml文件 ,输入命令:
mybatis-generator:generate -e
或者在命令行中输入:
mvn mybatis-generator:generate

方式一:运行pom.xml文件

pom运行.png

方式二:控制台输入命令运行


控制台运行效果.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343