eclipse通过generator逆向工程生成数据库model实体包和mapper映射包

此方法导入以下的代码后,用java的普通方式(java Application)运行,注意不要用Run on server

如题 ,本例子是通过web项目逆向工程
所以此项目需导入3个包
mybatis-3.2.6.jar
mybatis-generator-core-1.3.2.jar
mysql-connector-java-5.1.31.jar(此例用的mysql)
3个jar包都可以从maven仓库 下载 https://mvnrepository.com/artifact/org.molgenis/molgenis-security

一.在src源文件(非webcontent内)
( 直接创建一个java类GeneratorSqlmap.java
)
(只用在此java类中Main触发运行,不用修改代码)
注意:
import包不要导入错了
,其他则可以直接复制粘贴

    import java.io.File;
    import java.util.ArrayList;
    import java.util.List;
     
    import org.mybatis.generator.api.MyBatisGenerator;
    import org.mybatis.generator.config.Configuration;
    import org.mybatis.generator.config.xml.ConfigurationParser;
    import org.mybatis.generator.internal.DefaultShellCallback;
     

    public class GeneratorSqlmap {
    public static void main(String[] args) throws Exception {
        try {
            GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();
            generatorSqlmap.generator();
        } catch (Exception e) {
            e.printStackTrace();
        }
        
    }

    public void generator() throws Exception{
    	 
        List<String> warnings = new ArrayList<String>();
        boolean overwrite = true;
        //指定 逆向工程配置文件
                File configFile = new File("src/generatorConfig.xml");
        ConfigurationParser cp = new ConfigurationParser(warnings);
        Configuration config = cp.parseConfiguration(configFile);
        DefaultShellCallback callback = new DefaultShellCallback(overwrite);
        MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,
                callback, warnings);
        myBatisGenerator.generate(null);
 
    }
    }

2.在src源文件内(非webcontent内)建立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>
    <context id="testTables" targetRuntime="MyBatis3">
        <commentGenerator>
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="true" />
        </commentGenerator>
        <!--数据库连接的信息:驱动类、连接地址、用户名、密码,这里配置的是mysql的,当然也可以配置oracle等数据库 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/index" userId="root"
            password="">
        </jdbcConnection>
 
        <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 
            和 NUMERIC 类型解析为java.math.BigDecimal -->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
 
        <!-- targetProject:生成PO类的位置 1-->
        <javaModelGenerator targetPackage="cn.itcast.ssm.po"
            targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
            <!-- 从数据库返回的值被清理前后的空格 -->
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <!-- targetProject:mapper映射文件生成的位置 2.1-->
        <sqlMapGenerator targetPackage="cn.itcast.ssm.mapper"
            targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
        <!-- targetPackage:mapper接口生成的位置 2.2-->
        <javaClientGenerator type="XMLMAPPER"
            targetPackage="cn.itcast.ssm.mapper" targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>
        <!-- 指定数据库表 -->
        <table tableName="login"></table>
<!--         <table tableName="test"></table> -->
 
    </context>
</generatorConfiguration>

注意:其中一定需要更改的代码
1.jdbc连接

<jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/index" userId="root"
            password="">
        </jdbcConnection>

2.model实体类生成于该项目的地址

<javaModelGenerator targetPackage="cn.itcast.ssm.po"
           targetProject=".\src">

3.映射mapper类生成于该项目的地址

<sqlMapGenerator targetPackage="cn.itcast.ssm.mapper"
           targetProject=".\src">

4 指定生成任意个数的来源于数据库表的model实体类(一个实体类对应一个数据库表)

<table tableName="login"></table>(其中"login"为表名)
<!--         <table tableName="test"></table> -->
................

上述的文件配置完成后在 GeneratorSqlmap.java 处用 java Application方式运行
除非是报错,不然成功在控制台是没有任何提示的!!!

最后只需要将项目刷新就可以看到两者 生成了!!!
(成功后这些配置的文件可以选择删除了…)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值