使用mybatis时,会发现有一大堆的xml文件(映射文件),mapper文件,以及实体类等,这些是怎么生成的呢?
可以使用generator插件实现,具体来说:
1、在pom.xml文件中加入依赖
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.7</version>
</plugin>
2、编写generatorConfig.xml文件,
在idea开发环境下,这个文件需放置在resources的根目录下,文件内容如下:
<?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>
<properties resource="jdbc.properties" />
<!-- 数据库驱动:指定数据连接驱动jar地址,比如,驱动文件:mysql-connector-java-5.1.39.jar的地址 -->
<classPathEntry location="${jdbc.driverPath}" />
<!-- 此处指定生成针对MyBatis3的DAO -->
<context id="context" targetRuntime="MyBatis3">
<!-- 生成的Java文件的编码 -->
<property name="javaFileEncoding" value="UTF-8"/>
<!-- 格式化java代码 -->
<property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
<!-- 格式化XML代码 -->
<property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
<!--beginningDelimiter和endingDelimiter:指明数据库的用于标记数据库对象名的符号,比如ORACLE就是双引号,MYSQL默认是`反引号;-->
<property name="beginningDelimiter" value="`"/>
<property name="endingDelimiter" value="`"/>
<!-- 为生成的Java模型创建一个toString方法 -->
<plugin type="org.mybatis.generator.plugins.ToStringPlugin" />
<!-- JavaBean 实现 序列化 接口 -->
<plugin type="org.mybatis.generator.plugins.SerializablePlugin" />
<!-- 去掉生成出来的代码的注解 -->
<commentGenerator>
<property name="suppressAllComments" value="true" />
<property name="suppressDate" value="true" />
</commentGenerator>
<!--数据库链接URL,用户名、密码 -->
<jdbcConnection driverClass="${jdbc.driverClass}"
connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}">
</jdbcConnection>
<!-- 默认false,表示把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer; true表示把JDBC DECIMAL
和 NUMERIC 类型解析为java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 生成bean对象 -->
<javaModelGenerator targetPackage="${target_package}.pojo"
targetProject="${project}">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="true" />
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- 生成sqlMap映射文件 xml -->
<sqlMapGenerator targetPackage="${target_package}.mapping"
targetProject="${project}">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- 生成DAO的类文件 -->
<javaClientGenerator targetPackage="${target_package}.dao"
targetProject="${project}" type="XMLMAPPER">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名 -->
<table tableName="user" domainObjectName="User" > </table>
</context>
</generatorConfiguration>
说明:
1、${xxx} 取得是jdbc.properties中的内容
2、使用maven运行,主要生成三大类文件:
1)生成实体类(表的具体信息),bean对象,在pojo下;
2)生成映射文件 xml文件(可写sql相关语句),在mapping下;
3)生成mapper.java文件(数据库相关的操作),在dao文件下,Mapper;
3、创建maven运行项:
点击“Edit Configurations”,添加maven进行配置,parameters下的Command line为:mybatis-generator:generate -e
4、点击运行即可。