1. 程式人生 > >mybatis逆向工程使用

mybatis逆向工程使用

清除 html user resolve apple 工具 pac context 1.0

下面給大家介紹一種偷懶的生成工具使用--mybatis-generator,使用此插件可以從數據庫生成指定表格對應的實體類、mapper接口以及對應的xml文件(包含一些常用的方法實現)。

首先是通過maven添加插件引用

  1. <plugin>
  2. <groupId>org.mybatis.generator</groupId>
  3. <artifactId>mybatis-generator-maven-plugin</artifactId>
  4. <version>1.3.2</version>
  5. <configuration>
  6. <!--配置文件的位置-->
  7. <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
  8. <verbose>true</verbose>
  9. <overwrite>true</overwrite>
  10. </configuration>
  11. <executions>
  12. <execution>
  13. <id>Generate MyBatis Artifacts</id>
  14. <goals>
  15. <goal>generate</goal>
  16. </goals>
  17. </execution>
  18. </executions>
  19. <dependencies>
  20. <dependency>
  21. <groupId>org.mybatis.generator</groupId>
  22. <artifactId>mybatis-generator-core</artifactId>
  23. <version>1.3.2</version>
  24. </dependency>
  25. </dependencies>
  26. </plugin>

新建配置文件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. <generatorConfiguration>
  6. <!--mysql 連接數據庫jar 這裏選擇自己本地位置-->
  7. <classPathEntry location="D:\maven\repository\mysql\mysql-connector-java\5.1.34\mysql-connector-java-5.1.34.jar" />
  8. <context id="testTables" targetRuntime="MyBatis3">
  9. <commentGenerator>
  10. <!-- 是否去除自動生成的註釋 true:是 : false:否 -->
  11. <property name="suppressAllComments" value="true" />
  12. </commentGenerator>
  13. <!--數據庫連接的信息:驅動類、連接地址、用戶名、密碼 -->
  14. <jdbcConnection driverClass="com.mysql.jdbc.Driver"
  15. connectionURL="jdbc:mysql://localhost:3306/test?serverTimezone=UTC" userId="root"
  16. password="123456">
  17. </jdbcConnection>
  18. <!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer,為 true時把JDBC DECIMAL 和
  19. NUMERIC 類型解析為java.math.BigDecimal -->
  20. <javaTypeResolver>
  21. <property name="forceBigDecimals" value="false" />
  22. </javaTypeResolver>
  23. <!-- targetProject:生成PO類的位置 -->
  24. <javaModelGenerator targetPackage="com.example.demo.entry"
  25. targetProject="src/main/java">
  26. <!-- enableSubPackages:是否讓schema作為包的後綴 -->
  27. <property name="enableSubPackages" value="false" />
  28. <!-- 從數據庫返回的值被清理前後的空格 -->
  29. <property name="trimStrings" value="true" />
  30. </javaModelGenerator>
  31. <!-- targetProject:mapper映射文件生成的位置
  32. 如果maven工程只是單獨的一個工程,targetProject="src/main/java"
  33. 若果maven工程是分模塊的工程,targetProject="所屬模塊的名稱",例如:
  34. targetProject="ecps-manager-mapper",下同-->
  35. <sqlMapGenerator targetPackage="mapXml"
  36. targetProject="src/main/resources">
  37. <!-- enableSubPackages:是否讓schema作為包的後綴 -->
  38. <property name="enableSubPackages" value="false" />
  39. </sqlMapGenerator>
  40. <!-- targetPackage:mapper接口生成的位置 -->
  41. <javaClientGenerator type="XMLMAPPER"
  42. targetPackage="com.example.demo.mapper"
  43. targetProject="src/main/java">
  44. <!-- enableSubPackages:是否讓schema作為包的後綴 -->
  45. <property name="enableSubPackages" value="false" />
  46. </javaClientGenerator>
  47. <!-- 指定數據庫表 -->
  48. <table schema="" tableName="demo2"></table>
  49. </context>
  50. </generatorConfiguration>

配置文件需配置數據庫jar包位置,生成的文件存放位置等信息

IEDA配置運行選項:

技術分享圖片

運行環境配置中新增maven選項,Command Line項設置值為 mybatis-generator:generate -e

最後,選中generatorConfig.xml配置文件,以新建的方式運行

技術分享圖片

可以看到對應的文件已經生成,而且mapper中也生成了一些基礎的方法

MyEclipse中也有類似的無須maven引入的插件,可以自行百度了解其安裝方法

註意:

在上面的配置文件,有一個嚴重的問題,就是

  1. <commentGenerator>
  2. <!-- 是否去除自動生成的註釋 true:是 : false:否 -->
  3. <property name="suppressAllComments" value="true" />
  4. </commentGenerator>

這裏的註釋設置,最好設置為false,因為第二次更新生成代碼的時候,是會根據註釋中@mbggenerated來生成,如果去除自動生成的註釋,會引起XML代碼重復生成的問題,從而導致啟動報錯。

還有一個問題,在Maven插件設置中設置了

<overwrite>true</overwrite>

所以每次重新生成,Mapper會被覆蓋,這樣自己寫的接口會被清除,myeclipse中使用插件安裝是可以避免這個問題的,但是IDEA不行,最近在找方法解決中。。。

mybatis逆向工程使用