Mybatis generator
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis generator相关的知识,希望对你有一定的参考价值。
首先,要知道mybatis generator 是根据表来生成domain 和mapper以及mapper.xml文件的,必须先有表,它才能帮助你自动生成
其次,配置generatorConfig.xml文件
在这里,我用的是maven的配置方式,如下:
1 <build> 2 <plugins> 3 <plugin> 4 <groupId>org.mybatis.generator</groupId> 5 <artifactId>mybatis-generator-maven-plugin</artifactId> 6 <version>1.3.2</version> 7 <configuration> 8 <verbose>true</verbose> 9 <overwrite>false</overwrite> 10 </configuration> 11 <dependencies> 12 <dependency> 13 <groupId>mysql</groupId> 14 <artifactId>mysql-connector-java</artifactId> 15 <version>5.1.21</version> 16 </dependency> 17 </dependencies> 18 </plugin> 19 </plugins> 20 </build>
generatorConfig.xml的详细配置以及注释
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE generatorConfiguration 3 PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" 4 "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> 5 <!-- 配置生成器 --> 6 <generatorConfiguration> 7 <context id="mysql" defaultModelType="hierarchical" 8 targetRuntime="MyBatis3Simple"> 9 <!-- 自动识别数据库关键字,默认false,如果设置为true,根据SqlReservedWords中定义的关键字列表; 一般保留默认值,遇到数据库关键字(Java关键字),使用columnOverride覆盖 --> 10 <property name="autoDelimitKeywords" value="false" /> 11 <!-- 生成的Java文件的编码 --> 12 <property name="javaFileEncoding" value="UTF-8" /> 13 <!-- 格式化java代码 --> 14 <property name="javaFormatter" 15 value="org.mybatis.generator.api.dom.DefaultJavaFormatter" /> 16 <!-- 格式化XML代码 --> 17 <property name="xmlFormatter" 18 value="org.mybatis.generator.api.dom.DefaultXmlFormatter" /> 19 20 <!-- beginningDelimiter和endingDelimiter:指明数据库的用于标记数据库对象名的符号,比如ORACLE就是双引号,MYSQL默认是`反引号; --> 21 <property name="beginningDelimiter" value="`" /> 22 <property name="endingDelimiter" value="`" /> 23 <!-- 定义注释生成器 --> 24 <commentGenerator> 25 <property name="suppressDate" value="true" /> 26 <property name="suppressAllComments" value="true" /> 27 </commentGenerator> 28 29 <!-- 必须要有的,使用这个配置链接数据库 @TODO:是否可以扩展 --> 30 <jdbcConnection driverClass="com.mysql.jdbc.Driver" 31 connectionURL="jdbc:mysql:///p2p" userId="root" password="admin"> 32 <!-- 这里面可以设置property属性,每一个property属性都设置到配置的Driver上 --> 33 </jdbcConnection> 34 35 <!-- java类型处理器 用于处理DB中的类型到Java中的类型,默认使用JavaTypeResolverDefaultImpl; 注意一点,默认会先尝试使用Integer,Long,Short等来对应DECIMAL和 36 NUMERIC数据类型; --> 37 <javaTypeResolver 38 type="org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl"> 39 <!-- true:使用BigDecimal对应DECIMAL和 NUMERIC数据类型 false:默认, scale>0;length>18:使用BigDecimal; 40 scale=0;length[10,18]:使用Long; scale=0;length[5,9]:使用Integer; scale=0;length<5:使用Short; --> 41 <property name="forceBigDecimals" value="false" /> 42 </javaTypeResolver> 43 44 45 <!-- java模型创建器,是必须要的元素 负责:1,key类(见context的defaultModelType);2,java类;3,查询类 46 targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制; targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录 --> 47 <javaModelGenerator targetPackage="com.xmg.p2p.base.domain" 48 targetProject="src/main/java"> 49 <!-- for MyBatis3/MyBatis3Simple 自动为每一个生成的类创建一个构造方法,构造方法包含了所有的field;而不是使用setter; --> 50 <property name="constructorBased" value="false" /> 51 52 <!-- for MyBatis3 / MyBatis3Simple 是否创建一个不可变的类,如果为true, 那么MBG会创建一个没有setter方法的类,取而代之的是类似constructorBased的类 --> 53 <property name="immutable" value="false" /> 54 55 <!-- 设置是否在getter方法中,对String类型字段调用trim()方法 --> 56 <property name="trimStrings" value="true" /> 57 </javaModelGenerator> 58 59 <!-- 生成SQL map的XML文件生成器, 注意,在Mybatis3之后,我们可以使用mapper.xml文件+Mapper接口(或者不用mapper接口), 60 或者只使用Mapper接口+Annotation,所以,如果 javaClientGenerator配置中配置了需要生成XML的话,这个元素就必须配置 61 targetPackage/targetProject:同javaModelGenerator --> 62 <sqlMapGenerator targetPackage="com.xmg.p2p.base.mapper" 63 targetProject="src/main/java"> 64 <!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --> 65 <property name="enableSubPackages" value="true" /> 66 </sqlMapGenerator> 67 68 69 <!-- 对于mybatis来说,即生成Mapper接口,注意,如果没有配置该元素,那么默认不会生成Mapper接口 targetPackage/targetProject:同javaModelGenerator 70 type:选择怎么生成mapper接口(在MyBatis3/MyBatis3Simple下): 1,ANNOTATEDMAPPER:会生成使用Mapper接口+Annotation的方式创建(SQL生成在annotation中),不会生成对应的XML; 71 2,MIXEDMAPPER:使用混合配置,会生成Mapper接口,并适当添加合适的Annotation,但是XML会生成在XML中; 3,XMLMAPPER:会生成Mapper接口,接口完全依赖XML; 72 注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER --> 73 <javaClientGenerator targetPackage="com.xmg.p2p.base.mapper" 74 type="XMLMAPPER" targetProject="src/main/java"> 75 <!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --> 76 <property name="enableSubPackages" value="true" /> 77 78 <!-- 可以为所有生成的接口添加一个父接口,但是MBG只负责生成,不负责检查 <property name="rootInterface" 79 value=""/> --> 80 </javaClientGenerator> 81 82 <table tableName="logininfo"> 83 <!-- 参考 javaModelGenerator 的 constructorBased属性 --> 84 <property name="constructorBased" value="false" /> 85 <generatedKey column="id" sqlStatement="JDBC" /> 86 </table> 87 </context> 88 </generatorConfiguration>
以上是关于Mybatis generator的主要内容,如果未能解决你的问题,请参考以下文章
13.1 MyBatis Generator概述(MyBatis Generator逆向代码生成工具) -《SSM深入解析与项目实战》
mybatis代码生成器——MyBatis Generator
mybatis 生成代码配置 mybatis-generator:generate 的使用详解