使用mybatis外掛generator生成實體類,dao層和mapper對映
本文主要講如何使用generator外掛自動生成我們所需要的實體類,Dao層和對應的mapper對映檔案,首先講一下命令列下用本地jar包使用,然後再講專案中整合進generator外掛進行生成。現在教程開始(Mysql資料庫為例)
一 本地jar包進行自動生成
目錄結構
所需jar包
配置檔案內容
根據本地test資料庫中login表自動生成bean,dao,mapper
<?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\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar" /> <context id="DB2Tables" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressDate" value="true"/> <property name="javaFileEncoding" value="UTF-8"/> <!-- 是否去除自動生成的註釋 true:是 : false:否 --> <property name="suppressAllComments" value="false"/> </commentGenerator> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8" userId="root" password="root"> </jdbcConnection> <javaTypeResolver > <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="C:\Users\31283\Desktop\generator"> <property name="enableSubPackages" value="true" /> <property name="trimStrings" value="true" /> </javaModelGenerator> <sqlMapGenerator targetPackage="mapper" targetProject="C:\Users\31283\Desktop\generator\"> <property name="enableSubPackages" value="true" /> </sqlMapGenerator> <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql" targetProject="C:\Users\31283\Desktop\generator\"> <property name="enableSubPackages" value="true" /> </javaClientGenerator> <table tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> </context> </generatorConfiguration>
需要修改的地方
本地jar包路徑
<classPathEntry location="C:\Users\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar" /> <context id="DB2Tables" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressDate" value="true"/> <property name="javaFileEncoding" value="UTF-8"/> <!-- 是否去除自動生成的註釋 true:是 : false:否 --> <property name="suppressAllComments" value="false"/> </commentGenerator>
資料庫連線地址
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8"
userId="root"
password="root">
</jdbcConnection>
connectionURL:資料庫連線地址
userId:”資料庫連線使用者名稱
password: 資料庫連線使用者密碼
對應實體類路徑
<javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="C:\Users\31283\Desktop\generator">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
targetPackage:實體類要存在com.example.demo.bean.mysql包下面
targetProject:com.example.demo.bean.mysql包結構在C:\Users\31283\Desktop\generator目錄下面
對應mapper檔案路徑
<sqlMapGenerator targetPackage="mapper" targetProject="C:\Users\31283\Desktop\generator\">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
targetPackage:生成的xml檔案存在在mapper目錄下面
targetProject:mapper目錄在C:\Users\31283\Desktop\generator下面
對應Dao介面層路徑
<javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql" targetProject="C:\Users\31283\Desktop\generator\">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
type:XMLMAPPER
targetPackage:Dao介面層存在在com.example.demo.dao.mysql目錄下面
targetProject :com.example.demo.dao.mysql包目錄在C:\Users\31283\Desktop\generator下面
需要生成表配置項
<table tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
tableName: 資料庫表名
domainObjectName:生成實體類類名
執行命令
在C:\Users\31283\Desktop\generator\ 目錄下面,也就是我們的配置檔案目錄下面開啟命令列輸入一下命令執行即可
java -jar .\lib\mybatis-generator-core-1.3.2.jar -configfile .\generator.xml -overwrite
最終生成目錄結構
以上就是使用本地jar包的方式使用generator外掛自動生成實體類,Dao和mapper的過程
二 Maven專案整合generator外掛使用maven命令生成
1 resources目錄下新建generator資料夾
generator資料夾下面新建generatorConfig.xml
generatorConfig.xml檔案內容如下
<?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">
<!--使用此外掛可以自動根據資料庫生成dao,mapper以及bean,,maven命令 mybatis-generator:generate -e -->
<generatorConfiguration>
<!-- 資料庫驅動:選擇你的本地硬碟上面的資料庫驅動包-->
<classPathEntry location="C:\Users\31283\Desktop\generator\lib\mysql-connector-java-5.1.8-bin.jar"/>
<context id="DB2Tables" targetRuntime="MyBatis3">
<commentGenerator>
<property name="suppressDate" value="true"/>
<!-- 是否去除自動生成的註釋 true:是 : false:否 -->
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!--資料庫連結URL,使用者名稱、密碼 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1/test" userId="root" password="root">
</jdbcConnection>
<javaTypeResolver>
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!-- 生成模型的包名和位置-->
<javaModelGenerator targetPackage="com.example.demo.bean.mysql" targetProject="src/main/java">
<property name="enableSubPackages" value="true"/>
<property name="trimStrings" value="true"/>
</javaModelGenerator>
<!-- 生成對映檔案的包名和位置-->
<sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources">
<property name="enableSubPackages" value="true"/>
</sqlMapGenerator>
<!-- 生成DAO的包名和位置-->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao.mysql" targetProject="src/main/java">
<property name="enableSubPackages" value="true"/>
</javaClientGenerator>
<!-- 要生成的表 tableName是資料庫中的表名或檢視名 domainObjectName是實體類名-->
<table tableName="login" domainObjectName="Login" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
</context>
</generatorConfiguration>
需要修改的地方參照上邊本地jar包方式修改即可需要注意的就是實體類,Dao層和mapper檔案生成的位置變了,修改如下
targetProject="C:\Users\31283\Desktop\generator"
改為
targetProject="src/main/java"
maven的pom檔案中新增generator外掛
在pom檔案中新增以下程式碼
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.2</version>
<configuration>
<configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
<overwrite>true</overwrite>
<verbose>true</verbose>
</configuration>
</plugin>
使用maven命令執行,maven命令如下
mybatis-generator:generate –e
好了大功告成,以上就是使用本地jar以及maven專案整合外掛的方式分別進行實體類,Dao和mapper的生成過程,如有錯誤多多指教