一、File>Settings>Plugins,搜索mybatis-generator,默认没有安装。java
二、点击Search in repositories连接,选择idea-mybatis-generator插件,右侧窗口点击install按钮,安装完成后提示重启IDEA。mysql
三、配置idea-mybatis-generator插件spring
四、加号+新建maven,配置名称:MyBatis Generator,运行命令:mybatis-generator:generate -esql
五、配置好后,运行项目选择:MyBatis Generator数据库
六、 配置项目POM.xml文件(特别注意,这里一个坑,mybaits的plugin,必须在单独的plugins里面才会在右边的maven出来东西)mybatis
<plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--配置文件的位置--> <configurationFile>src/main/resources/MyBatisGenerator.xml</configurationFile> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> <executions> <execution> <id>Generate MyBatis Artifacts</id> <goals> <goal>generate</goal> </goals> </execution> </executions> </plugin>
七、项目resources下要有MyBatisGenerator.xml文件app
注:targetProject属性要配置为项目绝对路径,不然没法自动生成相关实体操做类。maven
其余参考文章:ide
https://www.cnblogs.com/heben/p/6088251.html
配置文件的样本以下:
<?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:/Users/Ash/.m2/repository/mysql/mysql-connector-java/5.1.30/mysql-connector-java-5.1.30.jar"/> <context id="productRelease"> <property name="mergeable" value="false" /> <plugin type="org.mybatis.generator.plugins.SerializablePlugin" /> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/springbankdb" userId="a" password="a" /> <javaModelGenerator targetPackage="com.springbank.dao.generate.model" targetProject="springbank-dao" /> <sqlMapGenerator targetPackage="com.springbank.dao.generate.mapper" targetProject="springbank-dao" /> <javaClientGenerator targetPackage="com.springbank.dao.generate.mapper" targetProject="springbank-dao" type="XMLMAPPER" /> <table tableName="owner" /> <table tableName="acctrate" /> <table tableName="acct" /> <table tableName="acctstatus" /> <table tableName="sysparam" /> <table tableName="rtxn" /> <table tableName="rate" /> <table tableName="ratetype" /> <table tableName="prod" /> <table tableName="rtxntypgl" /> <!-- <table tableName="scheduledjob" /> --> </context> </generatorConfiguration>
其余优化的参看文档:结合lombok