Mybatis generatorConfig.xml生成配置文件

目的:批量解決數(shù)據(jù)庫表與實(shí)體類,Mapper的一一對應(yīng);即當(dāng)數(shù)據(jù)庫表過多時掰曾,需要對每張表進(jìn)行增刪改查等系列操作時,一些實(shí)體類停团,dao層旷坦,mapper等基礎(chǔ)代碼需要花費(fèi)大量的時間編寫,使用generatorConfig.xml配置文件可自動生成基礎(chǔ)代碼佑稠,節(jié)省編程時間

步驟1.導(dǎo)入相關(guān)的jar

<build>

????<plugins>

????????<plugin>

????????????<groupId>org.mybatis.generator</groupId>

????????????<artifactId>mybatis-generator-maven-plugin</artifactId>

????????????<version>1.3.2</version>

????????????<configuration>

????????????????<verbose>true</verbose>

????????????????<overwrite>true </overwrite>

????????????</configuration>

????????</plugin>

????</plugins>

</build>

步驟2:數(shù)據(jù)庫信息配置文件config.properties(與generatorConfig.xml同目錄)

spring.datasource.url=XXX

spring.datasource.username=XXX

spring.datasource.password=XXX

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

步驟3:配置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">

<generatorConfiguration>

? ? ? ? <!--加載配置文件秒梅,為下面讀取數(shù)據(jù)庫信息準(zhǔn)備-->

? ? ? ? <properties resource="generator/config.properties"/>


????????<!--

????????context:生成一組對象的環(huán)境? ? ??

????????id:必選,上下文id舌胶,用于在生成錯誤時提示? ? ??

????????defaultModelType:指定生成對象的樣式? ? ? ? ??

????????????????1捆蜀,conditional:類似hierarchical;? ? ? ? ??

????????????????2幔嫂,flat:所有內(nèi)容(主鍵辆它,blob)等全部生成在一個對象中;? ? ? ? ??

????????????????3履恩,hierarchical:主鍵生成一個XXKey對象(key class)锰茉,Blob等單獨(dú)生成一個對象,其他簡單屬性在一個對象中(record class)

? ? ? ? targetRuntime:

? ? ? ? ? ? ? ?1切心,MyBatis3:默認(rèn)的值飒筑,生成基于MyBatis3.x以上版本的內(nèi)容,包括XXXBySample昙衅;? ? ? ? ??

? ? ? ? ? ? ? ?2扬霜,MyBatis3Simple:類似MyBatis3,只是不生成XXXBySample而涉;? ? ??

? ? ? ? introspectedColumnImpl:類全限定名著瓶,用于擴(kuò)展MBG

????????-->

? ? ? ? <context id="Mysql" targetRuntime="MyBatis3" defaultModelType="flat">


????????<!-- 注釋 -->

? ? ? ? <!-- 是否取消注釋 true:是 false:否 -->

????????<commentGenerator >

? ? ? ????????<property name="suppressAllComments" value="true"/>

????????</commentGenerator>


? ? ? <!--數(shù)據(jù)庫鏈接地址賬號密碼-->

? ? ? <jdbcConnection driverClass="com.mysql.jdbc.Driver"

? ? ? ? ? ? ? ? ? ? connectionURL="${spring.datasource.url}"??

? ? ? ? ? ? ? ? ? ? userId="XXX"

? ? ? ? ? ? ? ? ? ? password="XXX">

? ? ? </jdbcConnection>


? ? ????<!-- 類型轉(zhuǎn)換 -->

????????<!-- 默認(rèn)false,把JDBC DECIMAL 和 NUMERIC 類型解析為Integer-->

????????<!-- true啼县,把JDBC DECIMAL 和 NUMERIC 類型解析為java.math.BigDecimal-->

????????<javaTypeResolver>

? ? ? ? ????????<property name="forceBigDecimals" value="false"/>

????????</javaTypeResolver>


? ? ????<!--生成Model類存放位置-->

? ? ????<javaModelGenerator targetPackage="com.X.X.dao.entity" targetProject="src/main/java">

? ? ? ? ????????<!-- 從數(shù)據(jù)庫返回的值被清理前后的空格? -->

? ? ? ? ????????<property name="trimStrings" value="true"/>

? ?????</javaModelGenerator>

?

? ? ? ? <!-- 生成mapxml文件 -->

? ? ? ? <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources/" >

? ? ? ? <!--?是否允許子包材原,即targetPackage.schemaName.tableName?-->

? ? ? ? ? ? <!--?在targetPackage的基礎(chǔ)上,根據(jù)數(shù)據(jù)庫的schema再生成一層package季眷,最終生成的類放在這個package下余蟹,默認(rèn)為false?-->

? ? ? ????????<property name="enableSubPackages" value="true" />

????????</sqlMapGenerator>


? ? <!-- 生成mapxml對應(yīng)client,也就是接口dao -->

? ? <javaClientGenerator targetPackage="com.X.X.dao.mapper" targetProject="src/main/java" type="XMLMAPPER" >

? ? ? ????<property name="enableSubPackages" value="false" />

????</javaClientGenerator>


????<!--? ? ? database基本等同于schema-->

????<!--? ? ? mybatis generator自動生成的代碼里老是有一堆example子刮,雖然說他封裝的東西比較多威酒,但是大部分時候并不會用到,設(shè)置為false即可-->

? ? <table tableName="t_trans_price" schema="XXX"? enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false">

????????<!--? ? ? ? Mybatis逆向工程生成Entity,Mapper等文件窑睁,在有自增ID的時候,在generatorConfig.xml中對表的配置葵孤,都要加上一行g(shù)eneratedKey-->

? ? ????<!--? ? ? ? 這樣做的意義是担钮,調(diào)用mapper插入一條數(shù)據(jù)到數(shù)據(jù)庫之后,能從當(dāng)前這個Entity中獲取到插入之后的Id-->

? ? ? ?<generatedKey column="id" sqlStatement="Mysql" identity="true" />

? </table>

?</context>

</generatorConfiguration>

步驟4:點(diǎn)擊generatorConfig.xml對應(yīng)maven的mybatis-generator:generate自動生成相關(guān)文件


查看效果:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尤仍,一起剝皮案震驚了整個濱河市箫津,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宰啦,老刑警劉巖苏遥,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異赡模,居然都是意外死亡田炭,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進(jìn)店門漓柑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诫肠,“玉大人,你說我怎么就攤上這事欺缘。” “怎么了挤安?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵谚殊,是天一觀的道長。 經(jīng)常有香客問我蛤铜,道長嫩絮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任围肥,我火速辦了婚禮剿干,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘穆刻。我一直安慰自己置尔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布氢伟。 她就那樣靜靜地躺著榜轿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪朵锣。 梳的紋絲不亂的頭發(fā)上谬盐,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機(jī)與錄音诚些,去河邊找鬼飞傀。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的砸烦。 我是一名探鬼主播弃鸦,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼外冀!你這毒婦竟也來了寡键?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤雪隧,失蹤者是張志新(化名)和其女友劉穎西轩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體脑沿,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡藕畔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了庄拇。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片注服。...
    茶點(diǎn)故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖措近,靈堂內(nèi)的尸體忽然破棺而出溶弟,到底是詐尸還是另有隱情,我是刑警寧澤瞭郑,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布辜御,位于F島的核電站,受9級特大地震影響屈张,放射性物質(zhì)發(fā)生泄漏擒权。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一阁谆、第九天 我趴在偏房一處隱蔽的房頂上張望碳抄。 院中可真熱鬧,春花似錦场绿、人聲如沸剖效。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贱鄙。三九已至,卻和暖如春姨谷,著一層夾襖步出監(jiān)牢的瞬間逗宁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工梦湘, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瞎颗,地道東北人件甥。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像哼拔,于是被迫代替她去往敵國和親引有。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評論 2 345