首先需要准备的包为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个包,每个包里有一个自动生成的文件,就是我们想要的~