mybatis進(jìn)階1——代碼生成器MBG

1.概述

Mybatis Generator是一個(gè)很強(qiáng)大的代碼生成器,代碼包含了數(shù)據(jù)庫(kù)表對(duì)應(yīng)的實(shí)體類、Mapper接口類、Mapper XML文件和Example對(duì)象等,這些代碼文件中幾乎包含了全部的單表操作方法,使用MBG可以極大地方便我們使用MyBatis,減少很多重復(fù)工作。


2.配置文件

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>
    <!-- 引入配置文件 -->
    <properties resource="db.properties" />

    <!-- 加載數(shù)據(jù)庫(kù)驅(qū)動(dòng) -->
    <classPathEntry location="${class_path}" />

    <!-- context:生成一組對(duì)象的環(huán)境
            id:必選,上下文id,用于在生成錯(cuò)誤時(shí)提示
            defaultModelType:指定生成對(duì)象的樣式
                 1,conditional:類似hierarchical;
                 2,flat:所有內(nèi)容(主鍵,blob)等全部生成在一個(gè)對(duì)象中,推薦使用;
                 3,hierarchical:主鍵生成一個(gè)XXKey對(duì)象(key class),Blob等單獨(dú)生成一個(gè)對(duì)象,其他簡(jiǎn)單屬性在一個(gè)對(duì)象中(record class)
            targetRuntime:
                 1,MyBatis3:默認(rèn)的值,生成基于MyBatis3.x以上版本的內(nèi)容,包括XXXBySample;
                 2,MyBatis3Simple:類似MyBatis3,只是不生成XXXBySample;
     -->
    <context id="context1" targetRuntime="MyBatis3Simple"   defaultModelType="flat">

        <!-- 生成的Java文件的編碼 -->
        <property name="javaFileEncoding" value="UTF-8"/>


        <commentGenerator>
            <!-- 是否去除自動(dòng)生成的注釋 true:是 : false:否 -->
            <property name="suppressAllComments" value="false" />
            <!-- 阻止注釋中包含時(shí)間戳 true:是 : false:否 -->
            <property name="suppressDate" value="true" />
            <!--  注釋是否包含數(shù)據(jù)庫(kù)表的注釋信息  true:是 : false:否 -->
            <property name="addRemarkComments" value="true" />
        </commentGenerator>

        <!--數(shù)據(jù)庫(kù)連接的信息:驅(qū)動(dòng)類、連接地址、用戶名、密碼 -->
        <jdbcConnection driverClass="${jdbc_driver}"
                        connectionURL="${jdbc_url}" userId="${jdbc_username}" password="${jdbc_password}" />


        <!-- java模型創(chuàng)建器,是必須要的元素   負(fù)責(zé):1,key類(見context的defaultModelType);2,java類;3,查詢類
            targetPackage:生成的類要放的包,真實(shí)的包受enableSubPackages屬性控制;
            targetProject:目標(biāo)項(xiàng)目,指定一個(gè)存在的目錄下,生成的內(nèi)容會(huì)放到指定目錄中,如果目錄不存在,MBG不會(huì)自動(dòng)建目錄
        -->
        <javaModelGenerator targetPackage="com.enjoylearning.mybatis.entity" targetProject="${project_src}">
            <!-- 設(shè)置一個(gè)根對(duì)象,
                          如果設(shè)置了這個(gè)根對(duì)象,那么生成的keyClass或者recordClass會(huì)繼承這個(gè)類;在Table的rootClass屬性中可以覆蓋該選項(xiàng)
                          注意:如果在key class或者record class中有root class相同的屬性,MBG就不會(huì)重新生成這些屬性了,包括:
                    1,屬性名相同,類型相同,有相同的getter/setter方法;
             -->
            <property name="rootClass" value="com.enjoylearning.mybatis.entity.BaseEntity" />
        </javaModelGenerator>


        <!-- 生成SQL map的XML文件生成器,
            targetPackage:生成的類要放的包,真實(shí)的包受enableSubPackages屬性控制;
            targetProject:目標(biāo)項(xiàng)目,指定一個(gè)存在的目錄下,生成的內(nèi)容會(huì)放到指定目錄中,如果目錄不存在,MBG不會(huì)自動(dòng)建目錄
         -->
        <sqlMapGenerator targetPackage="." targetProject="${project_mapper_xml}">
        </sqlMapGenerator>


        <!-- 對(duì)于mybatis來(lái)說(shuō),即生成Mapper接口,注意,如果沒(méi)有配置該元素,那么默認(rèn)不會(huì)生成Mapper接口
               type:選擇怎么生成mapper接口(在MyBatis3/MyBatis3Simple下):
                   1,ANNOTATEDMAPPER:會(huì)生成使用Mapper接口+Annotation的方式創(chuàng)建(SQL生成在annotation中),不會(huì)生成對(duì)應(yīng)的XML;
                   2,MIXEDMAPPER:使用混合配置,會(huì)生成Mapper接口,并適當(dāng)添加合適的Annotation,但是XML會(huì)生成在XML中;
                   3,XMLMAPPER:會(huì)生成Mapper接口,接口完全依賴XML;
               注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER
           -->
        <javaClientGenerator  targetPackage="com.enjoylearning.mybatis.mapper"  targetProject="${project_src}" type="XMLMAPPER" />


        <!-- shema 數(shù)據(jù)庫(kù) tableName表明 -->
        <table schema="${jdbc_username}" tableName="%"  >
            <generatedKey column="id" sqlStatement="MySql"/>
        </table>


    </context>
</generatorConfiguration>

2.1 context屬性的說(shuō)明

  • id:必選,上下文id,用于在生成錯(cuò)誤時(shí)提示

  • defaultModelType:指定生成對(duì)象的樣式
    1)conditional:類似hierarchical;
    2)flat:所有內(nèi)容(主鍵,blob)等全部生成在一個(gè)對(duì)象中,推薦使用;
    3)hierarchical:主鍵生成一個(gè)XXKey對(duì)象(key class),Blob等單獨(dú)生成一個(gè)對(duì)象,其他簡(jiǎn)單屬性在一個(gè)對(duì)象中(record class)

  • targetRuntime:
    1)MyBatis3:默認(rèn)的值,生成基于MyBatis3.x以上版本的內(nèi)容,包括XXXBySample;
    2)MyBatis3Simple:類似MyBatis3,只是不生成XXXBySample;

  • java模型創(chuàng)建器,是必須要的元素
    負(fù)責(zé):
    1)key類(見context的defaultModelType);
    2)java類;
    3)查詢類
    targetPackage:生成的類要放的包,真實(shí)的包受enableSubPackages屬性控制;
    targetProject:目標(biāo)項(xiàng)目,指定一個(gè)存在的目錄下,生成的內(nèi)容會(huì)放到指定目錄中,如果目錄不存在,MBG不會(huì)自動(dòng)建目錄

  • 設(shè)置一個(gè)根對(duì)象
    如果設(shè)置了這個(gè)根對(duì)象,那么生成的keyClass或者recordClass會(huì)繼承這個(gè)類;在Table的rootClass屬性中可以覆蓋該選項(xiàng)
    注意:如果在key class或者record class中有root class相同的屬性,MBG就不會(huì)重新生成這些屬性了,包括:
    1)屬性名相同,類型相同,有相同的getter/setter方法;

  • 生成SQL map的XML文件生成器
    targetPackage:生成的類要放的包,真實(shí)的包受enableSubPackages屬性控制;
    targetProject:目標(biāo)項(xiàng)目,指定一個(gè)存在的目錄下,生成的內(nèi)容會(huì)放到指定目錄中,如果目錄不存在,MBG不會(huì)自動(dòng)建目錄

  • 對(duì)于mybatis來(lái)說(shuō),即生成Mapper接口,注意,如果沒(méi)有配置該元素,那么默認(rèn)不會(huì)生成Mapper接口
    type:選擇怎么生成mapper接口(在MyBatis3/MyBatis3Simple下):
    1)ANNOTATEDMAPPER:會(huì)生成使用Mapper接口+Annotation的方式創(chuàng)建(SQL生成在annotation中),不會(huì)生成對(duì)應(yīng)的XML;
    2)MIXEDMAPPER:使用混合配置,會(huì)生成Mapper接口,并適當(dāng)添加合適的Annotation,但是XML會(huì)生成在XML中;
    3)XMLMAPPER:會(huì)生成Mapper接口,接口完全依賴XML;
    注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER

3 運(yùn)行MBG

3.1 作為Maven Plugin

pom.xml中要加入插件:

            <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>

maven運(yùn)行配置如下:

mybatis-generator:generate

結(jié)果:

[INFO] Saving file TUserRoleMapper.java
[WARNING] Column id, specified as a generated key column in table t_user_role, does not exist in the table.
[WARNING] Root class com.enjoylearning.mybatis.entity.BaseEntity cannot be loaded, checking for member overrides is disabled for this class 
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.773 s
[INFO] Finished at: 2018-09-24T20:39:07+08:00
[INFO] ------------------------------------------------------------------------

需要加入com.enjoylearning.mybatis.entity.BaseEntity。

3.2 在Java中使用XML配置文件

MybatisSpringTest.java

    @Test
    public void mybatisGeneratorTest() throws FileNotFoundException {
        List<String> warnings = new ArrayList<String>();
        boolean overwrite = true;
        String genCfg = "generatorConfig.xml";
        File configFile = new File(getClass().getClassLoader().getResource(genCfg).getFile());
        ConfigurationParser cp = new ConfigurationParser(warnings);
        Configuration config = null;
        try {
            config = cp.parseConfiguration(configFile);
        } catch (IOException e) {
            e.printStackTrace();
        } catch (XMLParserException e) {
            e.printStackTrace();
        }
        DefaultShellCallback callback = new DefaultShellCallback(overwrite);
        MyBatisGenerator myBatisGenerator = null;
        try {
            myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
        } catch (InvalidConfigurationException e) {
            e.printStackTrace();
        }
        try {
            myBatisGenerator.generate(null);
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

3.3 從命令行使用xml配置文件

準(zhǔn)備好指定的文件夾、generatorConfig.xml配置文件和相應(yīng)的jar包。



執(zhí)行如下命令

java -Dfile.encoding=UTF-8 -jar mybatis-generator-core-1.3.5.jar -configfile generatorConfig.xml -overwrite

參考

  • 1)享學(xué)課堂Lison老師筆記
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容