Java借助Mybatis-generator生成po

在项目dao下resource下,借助Mybatis-generator生成表对应的po、mapper、mapper.xml

对应的,会有一个generatorConfig.properties文件作为配置文件

在generator-config.xml里面指明要生成的表名,里面的配置信息则是取自generatorConfig.properties文件中

<?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>
    <!--执行generator插件生成文件的命令:  mvn mybatis-generator:generate -e -->
    <!-- 引入配置文件 -->
    <properties resource="mybatis-generator/generatorConfig.properties"/>
    <!--classPathEntry:数据库的JDBC驱动,换成你自己的驱动位置 可选 -->
    <!--<classPathEntry location="D:generator_mybatismysql-connector-java-5.1.24-bin.jar" /> -->

    <!-- 一个数据库一个context -->
    <!--defaultModelType="flat" 大数据字段,不分表 -->
    <context id="MysqlTables" targetRuntime="MyBatis3" defaultModelType="flat">
        <!-- 自动识别数据库关键字,默认false,如果设置为true,根据SqlReservedWords中定义的关键字列表;
        一般保留默认值,遇到数据库关键字(Java关键字),使用columnOverride覆盖 -->
        <property name="autoDelimitKeywords" value="true" />
        <!-- 生成的Java文件的编码 -->
        <property name="javaFileEncoding" value="utf-8" />
        <!-- beginningDelimiter和endingDelimiter:指明数据库的用于标记数据库对象名的符号,比如ORACLE就是双引号,MYSQL默认是`反引号; -->
        <property name="beginningDelimiter" value="`" />
        <property name="endingDelimiter" value="`" />

        <!-- 格式化java代码 -->
        <property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
        <!-- 格式化XML代码 -->
        <property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin" />

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

        <commentGenerator >
            <!--<property name="suppressAllComments" value="true" />-->
            <property name="addRemarkComments" value="true"/>
            <property name="suppressDate" value="true"/>
        </commentGenerator>

        <!-- jdbc连接 -->
         <jdbcConnection driverClass="${jdbc.dataSource.driverClassName}" connectionURL="${jdbc.dataSource.url}" userId="${jdbc.dataSource.username}" password="${jdbc.dataSource.password}">
            <property name="remarksReporting" value="true"></property>
        </jdbcConnection>
        <!-- 类型转换 -->
        <javaTypeResolver>
            <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

         <!-- 生成实体类地址 -->
        <javaModelGenerator targetPackage="${model.package}" targetProject="src/main/java" >
            <property name="enableSubPackages" value="false"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!-- 生成map.xml文件 ${mapper.xml.path}-->
        <sqlMapGenerator targetPackage="${mapper.xml.package}" targetProject="src/main/resources" >
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
        <!-- 生成mapper文件,也就是接口dao -->
        <javaClientGenerator targetPackage="${dao.package}" targetProject="src/main/java" type="XMLMAPPER" >
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>
		
        <!-- table可以有多个,每个数据库中的表都可以写一个table,tableName表示要匹配的数据库表,也可以在tableName属性中通过使用%通配符来匹配所有数据库表,只有匹配的表才会自动生成文件 -->
            <!-- 如果设置为true,生成的model类会直接使用column本身的名字,而不会再使用驼峰命名方法,比如BORN_DATE,生成的属性名字就是BORN_DATE,而不会是bornDate -->
            <!-- <property name="useActualColumnNames" value="false" /> -->
          	
        <table tableName="TEST3" schema = "ds_u1"
               enableSelectByPrimaryKey="true" enableUpdateByPrimaryKey="true" enableDeleteByPrimaryKey="true"
               enableCountByExample="true" enableUpdateByExample="true"
               enableDeleteByExample="true" enableSelectByExample="true" selectByExampleQueryId="true" >
               <!-- 设置一个根对象,
			               如果设置了这个根对象,那么生成的keyClass或者recordClass会继承这个类;在Table的rootClass属性中可以覆盖该选项
			               注意:如果在key class或者record class中有root class相同的属性,MBG就不会重新生成这些属性了,包括:
                   1,属性名相同,类型相同,有相同的getter/setter方法;         -->
<!--            <property name="rootClass" value="com.erichfund.entry.po.BasePo" />-->
            
        </table>
    </context>
</generatorConfiguration>

然后借助maven下的Mybatis-generator生成就好了

Mybatis-generator是一个自动生成MyBatis代码的工具,可以快速生成Mapper、Dao、Entity等代码文件,可大大提高开发效率。如果需要多个项目使用相同的生成器配置,我们可以将该生成器打包成jar包,以供其他项目引用。 首先,在生成器的pom.xml文件中添加以下代码,将生成器打包成jar包: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <version>3.1.1</version> <configuration> <archive> <manifest> <addClasspath>true</addClasspath> <mainClass>org.mybatis.generator.api.ShellRunner</mainClass> </manifest> </archive> </configuration> </plugin> </plugins> </build> ``` 需要注意的是,这里需要指定MainClass为org.mybatis.generator.api.ShellRunner。 然后,执行以下Maven命令打包即可: ```bash mvn clean package ``` 生成的jar包位于target文件夹下。 接下来,我们可以将生成的jar包引入到其他项目中,在其他项目的pom.xml文件中添加以下依赖: ```xml <dependencies> <dependency> <groupId>com.company</groupId> <artifactId>mybatis-generator</artifactId> <version>1.0-SNAPSHOT</version> <scope>provided</scope> </dependency> </dependencies> ``` 其中,groupId和artifactId需要根据实际项目名称进行修改,version则要对应生成的jar包版本号。 最后,在其他项目中,可以通过在命令行中执行以下命令运行自定义生成器: ```bash java -jar mybatis-generator.jar -configfile generatorConfig.xml -overwrite ``` 其中,generatorConfig.xml为自定义的生成器配置文件,-overwrite示覆盖已存在的文件。 通过以上步骤,我们就可以自定义Mybatis-generator生成器并将其打包成jar包,以供其他项目引用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值