Intellij IDEA利用generatorConfig.xml反向生成java類


來源於 https://blog.csdn.net/zt1090258642/article/details/93083209

 

數據庫的表需要提前創建好

1.導入pom.xml文件依賴

 

 1 <!--mybatis自動生成工具 start-->
 2             <plugin>
 3                 <groupId>org.mybatis.generator</groupId>
 4                 <artifactId>mybatis-generator-maven-plugin</artifactId>
 5                 <version>1.3.2</version>
 6                 <executions>
 7                     <execution>
 8                         <id>Generate MyBatis Artifacts</id>
 9                         <goals>
10                             <goal>generate</goal>
11                         </goals>
12                     </execution>
13                 </executions>
14                 <configuration>
15                     <!-- generator 工具配置文件的位置 -->
16                     <configurationFile>src/main/resources/mybatis-generator/generatorConfig.xml</configurationFile>
17                     <!--注意這個位置要和自己的路徑一樣-->
18                     <verbose>true</verbose>
19                     <overwrite>true</overwrite>
20                 </configuration>
21                 <dependencies>
22                     <dependency>
23                         <groupId>mysql</groupId>
24                         <artifactId>mysql-connector-java</artifactId>
25                         <version>5.1.34</version>
26                     </dependency>
27                     <dependency>
28                         <groupId>org.mybatis.generator</groupId>
29                         <artifactId>mybatis-generator-core</artifactId>
30                         <version>1.3.2</version>
31                     </dependency>
32                 </dependencies>
33             </plugin>
34             <!--mybatis自動生成工具 start-->

 

 

主要是mybatis_generator中的兩個配置文件

2.1 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     <!--執行generator插件生成文件的命令: call mvn mybatis-generator:generate -e -->
 8     <!-- 引入配置文件 -->
 9     <properties resource="mybatis-generator/mybatisGeneratorinit.properties"/>
10     <!--classPathEntry:數據庫的JDBC驅動,換成你自己的驅動位置 可選 -->
11     <!--<classPathEntry location="D:\generator_mybatis\mysql-connector-java-5.1.24-bin.jar" /> -->
12  
13     <!-- 一個數據庫一個context -->
14     <!--defaultModelType="flat" 大數據字段,不分表 -->
15     <context id="MysqlTables" targetRuntime="MyBatis3Simple" defaultModelType="flat">
16         <!-- 自動識別數據庫關鍵字,默認false,如果設置為true,根據SqlReservedWords中定義的關鍵字列表;
17         一般保留默認值,遇到數據庫關鍵字(Java關鍵字),使用columnOverride覆蓋 -->
18         <property name="autoDelimitKeywords" value="true" />
19         <!-- 生成的Java文件的編碼 -->
20         <property name="javaFileEncoding" value="utf-8" />
21         <!-- beginningDelimiter和endingDelimiter:指明數據庫的用於標記數據庫對名的符號,比如ORACLE就是雙引號,MYSQL默認是`反引號; -->
22         <property name="beginningDelimiter" value="`" />
23         <property name="endingDelimiter" value="`" />
24  
25         <!-- 格式化java代碼 -->
26         <property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
27         <!-- 格式化XML代碼 -->
28         <property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
29         <plugin type="org.mybatis.generator.plugins.SerializablePlugin" />
30  
31         <plugin type="org.mybatis.generator.plugins.ToStringPlugin" />
32  
33         <!-- 注釋 -->
34         <commentGenerator >
35             <property name="suppressAllComments" value="false"/><!-- 是否取消注釋 -->
36             <property name="suppressDate" value="true" /> <!-- 是否生成注釋代時間戳-->
37         </commentGenerator>
38  
39         <!-- jdbc連接 -->
40         <jdbcConnection driverClass="${jdbc_driver}" connectionURL="${jdbc_url}" userId="${jdbc_user}" password="${jdbc_password}" />
41         <!-- 類型轉換 -->
42         <javaTypeResolver>
43             <!-- 是否使用bigDecimal, false可自動轉化以下類型(Long, Integer, Short, etc.) -->
44             <property name="forceBigDecimals" value="false"/>
45         </javaTypeResolver>
46  
47         <!-- 生成實體類地址 -->
48         <javaModelGenerator targetPackage="com.zt.springboot.model" targetProject="${project}" >
49             <property name="enableSubPackages" value="false"></property>
50             <property name="trimStrings" value="true"/>
51         </javaModelGenerator>
52         <!-- 生成mapxml文件 -->
53         <sqlMapGenerator targetPackage="mapper" targetProject="${resources}" >
54             <property name="enableSubPackages" value="false" />
55         </sqlMapGenerator>
56         <!-- 生成mapxml對應client,也就是接口dao -->
57         <javaClientGenerator targetPackage="com.zt.springboot.mapper" targetProject="${project}" type="XMLMAPPER" >
58             <property name="enableSubPackages" value="false" />
59         </javaClientGenerator>
60         <!-- table可以有多個,每個數據庫中的表都可以寫一個table,tableName表示要匹配的數據庫表,也可以在tableName屬性中通過使用%通配符來匹配所有數據庫表,只有匹配的表才會自動生成文件 -->
61         <!--<table tableName="wz_roler" enableCountByExample="true" enableUpdateByExample="true" enableDeleteByExample="true" enableSelectByExample="true" selectByExampleQueryId="true">-->
62             <!--<property name="useActualColumnNames" value="false" />-->
63             <!--&lt;!&ndash; 數據庫表主鍵 &ndash;&gt;-->
64             <!--<generatedKey column="uid" sqlStatement="Mysql" identity="true" />-->
65         <!--</table>-->
66  
67  
68  
69         <table tableName="admin_user" enableCountByExample="true" enableUpdateByExample="true" enableDeleteByExample="true" enableSelectByExample="true" selectByExampleQueryId="true">
70  
71             <property name="user_id" value="false" />
72             <!-- 數據庫表主鍵 -->
73             <generatedKey column="user_id" sqlStatement="Mysql" identity="true" />
74         </table>
75     </context>
76 </generatorConfiguration>

 

2.2 mybatisGeneratorinit.properties

#Mybatis Generator configuration
#dao類和實體類的位置
project=src/main/java
#mapper文件的位置
resources=src/main/resources
#根據數據庫中的表生成對應的pojo類、**Mapper、**Mapper.xml
jdbc_driver=com.mysql.jdbc.Driver
#連接數據庫
jdbc_url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf8
#數據庫名字
jdbc_user=root
#數據庫密碼
jdbc_password=123456

 

 

 

 

然后就運行成功啦

畫紅線是生成的

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM