IDEA+Maven+Mybatis Generator自动生成代码

      由于本人最近在学的MyBatis的的的框架,期间偶然看见一个叫逆向工程可以自动生成代码的东西,所以就入坑了。所以现在就把我的整个流程贡献出来。因为之前是看了很多资料,但是很多都可能报错,所有我现在整合起来一起发出来,倾删!

开发软件:IntelliJ IDEA 2017(本人喜欢用2017版)  

JDK 1.8驱动:MySQL的连接器的Java-5.1.0-bin.jar(版本不同没多大关系)

 

一:创建的的Maven的项目

(1)首先选择新建一个文件

(2)选择的的Maven的选择从原型创建记得选择JDK哦

(3)点击下一步输入组名的的的GroupId和项目名的的artifactId的版本默认就好版本其他的不要动点击下一步

(4)这里是配置的的Maven的仓库我是安装了其他的版本,默认就好点击下一步

(5)写好自己的项目名项目名称和路径项目位置然后点击完成

(6)然后是打开视图方式选择此窗口会替换当前窗口新窗口会打开一个个新窗口这个随便

 (7)这个是的Maven的的项目的结构这里就不多讲解了其中的的pom.xml中是的Maven的的项目核心配置文件,请不要乱改

(8)第一次加载的Maven的的项目会下载一些东西请耐心等待然后选择启用自动导入他会主动根据pom.xml中的中的一些依赖主动下载罐包

(9)讲解一些的的Maven的项目最好用的地方就是不要自己去加什么罐包驱动什么的,只要拿到依赖就行了。

二:配置Maven pom.xml文件

(1)在pom.xml中添加依赖

<dependency>
  <groupId>org.mybatis.generator</groupId>
  <artifactId>mybatis-generator-core</artifactId>
  <version>1.3.5</version>
</dependency>

(2)然后在<plugins> </ plugins>中添加配置 

<!-- 配置文件 -->
<plugin>
  <groupId>org.mybatis.generator</groupId>
  <artifactId>mybatis-generator-maven-plugin</artifactId>
  <version>1.3.2</version>
  <executions>
    <execution>
      <id>Generate MyBatis Files</id>
      <goals>
        <goal>generate</goal>
      </goals>
      <phase>generate</phase>
      <configuration>
        <verbose>true</verbose>
        <overwrite>true</overwrite>
      </configuration>
    </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>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.2</version>
    </dependency>
  </dependencies>
</plugin>

四:在src \ mian下面创建一个java包存放java代码和一个资源包存放项目所需的资源

然后右键选择java - >将目录标记为 - >源根目录

表示这个文件夹及其子文件夹中包含的源代码,可以编译为构建过程的一部分

同理把资源变成资源根表示用于应用程序中的资源文件(图像,各种配置XML和属性文件等)。

(1)在java的的的中创建道,映射器,型号三层   

        在资源中创建generator.properties和generatorConfig.xml两个配置文件

         最后总体结构如下:

(2)generator.properties代码如下:

#驱动文件位置
jdbc.driverLocation=E:\\mysql-connector-java-5.1.0-bin.jar
jdbc.driverClass=com.mysql.jdbc.Driver
#连接属性  一般来说就改数据库名就行了  我的数据库名是web
jdbc.connectionURL=jdbc:mysql://127.0.0.1:3306/web
#账号
jdbc.userId=root
#密码
jdbc.password=123

(3)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="generator.properties"></properties>

    <!--指定特定数据库的jdbc驱动jar包的位置-->
    <classPathEntry location="${jdbc.driverLocation}"/>

    <context id="default" targetRuntime="MyBatis3">

        <!-- optional,旨在创建class时,对注释进行控制 -->
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>

        <!--jdbc的数据库连接 -->
        <jdbcConnection
                driverClass="${jdbc.driverClass}"
                connectionURL="${jdbc.connectionURL}"
                userId="${jdbc.userId}"
                password="${jdbc.password}">
        </jdbcConnection>


        <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>


        <!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类
            targetPackage     指定生成的model生成所在的包名
            targetProject     指定在该项目下所在的路径
        -->
        <javaModelGenerator targetPackage="com.kt.Mybatis.model"
                            targetProject="src/main/java">

            <!-- 是否允许子包,即targetPackage.schemaName.tableName -->
            <property name="enableSubPackages" value="false"/>
            <!-- 是否对model添加 构造函数 -->
            <property name="constructorBased" value="true"/>
            <!-- 是否对类CHAR类型的列的数据进行trim操作 -->
            <property name="trimStrings" value="true"/>
            <!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 -->
            <property name="immutable" value="false"/>
        </javaModelGenerator>

        <!--Mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件 -->
        <sqlMapGenerator targetPackage="com.kt.Mybatis.mapper"
                         targetProject="src/main/java">
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!-- 客户端代码,生成易于使用的针对Model对象和XML配置文件 的代码
                type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象
                type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象
                type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口
        -->
        <javaClientGenerator targetPackage="com.kt.Mybatis.dao"
                             targetProject="src/main/java" type="XMLMAPPER">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>


        <!-- tableName 数据库中表名
             domainObjectName 生成代码的类名
             enableCountByExample(默认true):MyBatis3Simple为false,指定是否生成动态查询总条数语句(用于分页的总条数查询)
             enableUpdateByExample(默认true):MyBatis3Simple为false,指定是否生成动态修改语句(只修改对象中不为空的属性)
             enableDeleteByExample(默认true):MyBatis3Simple为false,指定是否生成动态删除语句
             enableSelectByExample(默认true):MyBatis3Simple为false,指定是否生成动态查询语句
             selectByExampleQueryId 这个不是很清楚 大概说明是关于主键吧!
             设置这些属性为false则不生成相应的Example类
        -->

        <table tableName="app" domainObjectName="App"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>

        <table tableName="pet" domainObjectName="Pet"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
        <table tableName="club" domainObjectName="Club"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
        <table tableName="product" domainObjectName="Product"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
        <table tableName="user" domainObjectName="User"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>

    </context>
</generatorConfiguration>

大概要改的是路径

五:运行发电机插件 

(1)选择编辑配置...

(2)点击“+”号选择的Maven的的

(3)把名字改为发生器工作目录默认   

    命令行:mybatis-generator:generate -e这里是用命令运行的

    然后点击保存申请

(4)运行发电机就可以了

(5)运行之后结构如下:

 

第一次写博客,如果本文对你有帮助记得点个赞!转发请标注出处!

附:码云地址代码   https://gitee.com/xingrui_jie/ReverseMybatis.git      需要代码的自取

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值