Mybatis自动生成实体类、mapper.xml和dao

首先需要准备的包为mybatis、mybatis-generator-core、mysql-connector-java三个jar包。

然后需要一个配置文件,如下,注释蛮详细的:

<?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>    
<!-- 数据库驱动,此处最好写全路径名,我的电脑必须要-->    
    <classPathEntry  location="D:\J2EEworkspace\MyBatis\WebContent\WEB-INF\lib\mysql-connector-java-5.1.7-bin.jar"/>    
    <context id="DB2Tables"  targetRuntime="MyBatis3">    
        <commentGenerator>    
            <property name="suppressDate" value="true"/>    
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->    
            <property name="suppressAllComments" value="true"/>    
        </commentGenerator>    
        <!--数据库链接URL,用户名、密码 -->    
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql:///ssm" userId="root" password="root">    
        </jdbcConnection>    
        <javaTypeResolver>    
        <!-- 默认为false,把decimal和numeric类型解析成Integer类型,为true时解析成BigDecimal类型 -->
            <property name="forceBigDecimals" value="false"/>    
        </javaTypeResolver>    
        <!-- 生成模型的包名和包所在位置-->    
        <javaModelGenerator targetPackage="com.cl.pojo" targetProject="src">    
        <!-- 是否让scheme作为包的后缀,这个可以不要,后面不设置schema即可 -->
            <property name="enableSubPackages" value="false"/>    
            <!-- 数据库返回的值处理掉空格 -->
            <property name="trimStrings" value="true"/>    
        </javaModelGenerator>    
        <!-- 生成映射文件的包名和位置-->    
        <sqlMapGenerator targetPackage="com.cl.mapper" targetProject="src">    
            <property name="enableSubPackages" value="false"/>    
        </sqlMapGenerator>    
        <!-- 生成DAO的包名和位置-->    
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.cl.dao" targetProject="src">    
            <property name="enableSubPackages" value="false"/>    
        </javaClientGenerator>    
        <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名,注意首字母要大写,即User,其他的false是用于不要让它产生可能不想要的方法-->    
        <table schema="untodo" tableName="user_t" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>  
    </context>    
</generatorConfiguration>  

配置文件准备好之后,我们有2种方式自动创建:

1;控制台命令:进行lib目录(即下面jar包所在文件夹)下,执行脚本,注意包的版本和配置文件名:

java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfig.xml -overwrite

上面这种方式最好将配置文件和jar包放一起,然后进入这个文件夹去执行脚本。这样的话sql-connector-java和配置文件不用写全路径。

2;我更喜欢写一个工具类来执行,如下:

package com.cl.mybatisUtils;

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;

//工具用于自动根据表生成实体类、mapper.xml、dao
public class GeneratorSqlMap {
public void generator() throws Exception{
    List<String> warnings=new ArrayList<String>();
    boolean overwrite=true;

//注意此处写全路径名,至少我的电脑要

    File configFile=new File("D:\\J2EEworkspace\\MyBatis\\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);
}
public static void main(String[] args){
    try {
        GeneratorSqlMap generatorSqlMap=new GeneratorSqlMap();
        generatorSqlMap.generator();
    }catch(Exception e){
        e.printStackTrace();
    }
}
}

运行以上程序,即可以在目标文件夹src下生成3个包,每个包里有一个自动生成的文件,就是我们想要的~

猜你喜欢

转载自blog.csdn.net/qq_26567507/article/details/78888468