1、修改maven的pom文件
只需要將如下依賴添加到pom.xml文件中即可。(注意此處是以plugin的方式,放在<plugins>
</plugins>
中間即可)
<plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</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>
<!-- 數據庫驅動:選擇你的本地硬盤上面的數據庫驅動包-->
<classPathEntry location="C:\MavenBox\myproj\mysql\mysql-connector-java\8.0.17\mysql-connector-java-8.0.17.jar"/>
<context id="DB2Tables" targetRuntime="MyBatis3">
<!-- 生成的Java文件的編碼 -->
<property name="javaFileEncoding" value="UTF-8" />
<property name="javaFileEncoding" value="UTF-8" />
<!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer,為 true 時把JDBC DECIMAL 和 NUMERIC 類型解析為java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- JavaBean 實現 序列化 接口 --> <plugin type="org.mybatis.generator.plugins.SerializablePlugin"/> <commentGenerator> <property name="suppressDate" value="true"/> <!-- 是否去除自動生成的注釋 true:是 : false:否 --> <property name="suppressAllComments" value="false"/> </commentGenerator> <!--數據庫鏈接URL,用戶名、密碼 --> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1:3306/workflow?useUnicode=true" userId="myproj" password="myproj"> </jdbcConnection> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!-- 生成模型的包名和位置--> <javaModelGenerator targetPackage="com.myproj.workflow.entity" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- 生成映射文件的包名和位置--> <sqlMapGenerator targetPackage="mapper.workflow" targetProject="src/main/resources"> <property name="enableSubPackages" value="true"/> </sqlMapGenerator> <!-- 生成mapper.java的包名和位置--> <javaClientGenerator type="XMLMAPPER" targetPackage="com.myproj.workflow.mapper" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!-- 要生成的表 tableName是數據庫中的表名或視圖名 domainObjectName是實體類名--> <table tableName="proc_model" domainObjectName="ProcModel" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> </context> </generatorConfiguration>
文件的位置如下
3、創建maven運行項
原文轉自:https://blog.csdn.net/yangqinfeng1121/article/details/80183516
后續:設置字段中文注釋:
mybatis generator 生成帶中文注釋的model類
將mybatis-generator-core-1.3.2.jar包中的org.mybatis.generator.interal.DefaultCommentGenerator類的addFieldComment方法重寫,代碼如下:
public void addFieldComment(Field field, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn) { if (suppressAllComments) { return; } StringBuilder sb = new StringBuilder(); field.addJavaDocLine("/**"); //$NON-NLS-1$ // field.addJavaDocLine(" * This field was generated by MyBatis Generator."); //$NON-NLS-1$ sb.append(" * "); //$NON-NLS-1$ sb.append(introspectedColumn.getRemarks()); sb.append(",所屬表字段為"); sb.append(introspectedTable.getFullyQualifiedTable()); sb.append('.'); sb.append(introspectedColumn.getActualColumnName()); field.addJavaDocLine(sb.toString()); // addJavadocTag(field, false); field.addJavaDocLine(" */"); //$NON-NLS-1$ }
然后編譯后,在放入jar包。
在mybatis生成代碼的xml配置文件中,
<-- oracle獲取注釋 --> <property name="remarksReporting" value="true"></property> <!-- commentGenerator里面加:--> <property name="javaFileEncoding" value="UTF-8"/>
為了防止生成的文件是gbk編碼,需要將eclipse或者idea的配置內存的那個文件,打開,加一句話:
-Dfile.encoding=UTF-8
也可直接下載:https://download.csdn.net/download/qq_29299555/12408152