关于使用mybatis jar包自动构建代码

         其实,很多关于使用mybatis jar包自动构建代码,随便一百度,就能有一堆,那么很明显,我的意图并不在于说明这个东西,他要怎么用,而是说说用了几个后的感觉。以及从我个人角度来说用起来的简易程度,(其实是要下班了,我凑一下时间而已)

      有个原因是我开始百度这个东西的动力,只从到了这家新的公司以后,我发现,一个新的项目中要建model、mapper.java、和mapper.xml等文件居然要去手写,实体类的封装是一个一个写的,想想都可怕,我在上一家公司里用的就是插件,在建好表后,直接运行某个类,自动就生成了相关文件,那么这样是可以的,为什么不试试看呢,在说手写不会累吗,于是就开始百度、测试、总结,今天分享一下,对自己有个交代吧!

      一,最早接触的是这种

具体操作,我就懒得说了,这个其实有点麻烦的,但是也很好理解,需要早cmd窗口里运行jar包,然后在文件里就生成的相关的文件,总的来说好理解但是我觉得麻烦,因为自动重写的代码不是在项目里,而是在某个文件夹里,需要去复制,修改名称什么的,然后运行的时候也要小心点才行,不然很用易出错


  二,后来,有时候没有那么忙了,就闲着又看到一个,于是又试试

MyBatis-plus  代码自动生成器

这个好多了,添加依赖,然后配置好包名、文件名,直接运行java文件就可以了,这个说实话那是相当简单,你要做的就是复制修改部分文件名称,但是到后来也有个问题,因为自动重写的代码不是在项目里,而是在某个文件夹里,需要去复制,修改名称什么的,然后运行的时候也要小心点才行,不然很用易出错,这时候还是不还用。

  三,再后来,嘿,发现了一个新的这回配置好了以后直接生成在项目里了哈哈哈

具体点是这么做的

1 在pom里添加依赖

<build>

    <finalName>crmpro</finalName>
    <!--generator自动生成代码文本依赖-->
    <plugins>
        <plugin>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.2</version>
            <configuration>
                <!--指定generatorConfig.xml文件地址-->
                <configurationFile>src\main\resources\generatorConfig.xml</configurationFile>
                <verbose>true</verbose>
                <overwrite>true</overwrite>
            </configuration>
            <executions>
                <execution>
                    <id>GenerateMyBatis Artifacts</id>
                    <goals>
                        <goal>generate</goal>
                    </goals>
                </execution>
            </executions>
            <dependencies>
                <dependency>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-core</artifactId>
                    <version>1.3.2</version>
                </dependency>
            </dependencies>
        </plugin>

    </plugins>
</build>

这里需要注意的就是要在build里添加plugins,然后添加,还有就是需要指定xml文件的地址,

2 然后就是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>

    <!--导入jdbc配置文件-->
    <properties resource="jdbc.properties"></properties>


    <!--指定数据库的jdbc驱动jar包的位置  此处需要指明mysql-connector-java-5.1.39.jar的绝对路径,否则会报错!-->
    <classPathEntry
            location="C:\Users\Administrator\.m2\repository\mysql\mysql-connector-java\5.1.39\mysql-connector-java-5.1.39.jar"/>


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

        <!-- optional,旨在创建class时,对注释进行控制 -->
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <!-- 是否去除自动生成的注释 true:是 : false:-->
            <property name="suppressAllComments" value="true"/>

        </commentGenerator>

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

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


        <!-- 生成模型model的包名和位置 -->
        <!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example
             targetPackage     指定生成的model生成所在的包名
             targetProject     指定在该项目下所在的路径-->

        <javaModelGenerator targetPackage="crm.pro.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="crm.pro.mapping" 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 type="XMLMAPPER" targetPackage="crm.pro.mapper" targetProject="./src/main/java">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>

        <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名 -->
        <table tableName="t_student_teacher" domainObjectName="StudentTeacher" enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>

        <!--使用说明:在右侧的MavenProjects
         Plugins == mybatis-genertator 单机运行
         出现 BUILD SUCCESS 成功或者查看报错信息找到问题
         自动在配置好的项目文件里产生相关的文件

         -->

    </context>

</generatorConfiguration>

这里需要注意的是

导入jdbc配置文件的时候,这里按住ctrl并不会跳转,所以路径不能错,否者数据库连不上,

还有就是怎找到自己的jdbc的驱动包所在的位置呢,我是拒绝的,后来在依赖里看到mysql***什么什么的,于是找找看,还确实找到了。点击右键find in path 就是,然后当进去就好了,别的配置文件的注释很清楚,就不用说了

总结一下,就是这个方法不用复制文件了,直接在项目里,这真是一个好办法,总的来说这个简单多了,其实就像走路一样,刚开始有点难,后来发现走路真好,坐上车以后才觉得走路不好,后来发现还有高铁!其实技术很多,主要是要用起来,今天我说的我都更新分享到我们项目组了,可是,上次建项目,依然还是手写的文件,我有点累了




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值