mybatis 三劍客

mybatis-generator

根據(jù)數(shù)據(jù)庫自動生成POJO 、dao和對應(yīng)的XML文件

Pojo: 里面放的跟DB一一對應(yīng)的對象
dao:是接口,供service調(diào)用
XML:是dao接口的實現(xiàn),SQL語句寫在這里

如何安裝

在porm里面添加

 <build>
<finalName>mmall</finalName>
<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>

如何配置


      <?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>
<!--導(dǎo)入屬性配置-->
<properties resource="datasource.properties"></properties>

<!--指定特定數(shù)據(jù)庫的jdbc驅(qū)動jar包的位置-->
<classPathEntry location="${db.driverLocation}"/>

<context id="default" targetRuntime="MyBatis3">

    <!-- optional臭挽,旨在創(chuàng)建class時,對注釋進行控制 -->
    <commentGenerator>
        <property name="suppressDate" value="true"/>
        <property name="suppressAllComments" value="true"/>
    </commentGenerator>

    <!--jdbc的數(shù)據(jù)庫連接 -->
    <jdbcConnection
            driverClass="${db.driverClassName}"
            connectionURL="${db.url}"
            userId="${db.username}"
            password="${db.password}">
    </jdbcConnection>


    <!-- 非必需,類型處理器坛梁,在數(shù)據(jù)庫類型和java類型之間的轉(zhuǎn)換控制-->
    <javaTypeResolver>
        <property name="forceBigDecimals" value="false"/>
    </javaTypeResolver>


    <!-- Model模型生成器,用來生成含有主鍵key的類,記錄類 以及查詢Example類
        targetPackage     指定生成的model生成所在的包名
        targetProject     指定在該項目下所在的路徑
    -->
    <!--<javaModelGenerator targetPackage="com.mmall.pojo" targetProject=".\src\main\java">-->
    <javaModelGenerator targetPackage="com.mmall.pojo" targetProject="./src/main/java">
        <!-- 是否允許子包腊凶,即targetPackage.schemaName.tableName -->
        <property name="enableSubPackages" value="false"/>
        <!-- 是否對model添加 構(gòu)造函數(shù) -->
        <property name="constructorBased" value="true"/>
        <!-- 是否對類CHAR類型的列的數(shù)據(jù)進行trim操作 -->
        <property name="trimStrings" value="true"/>
        <!-- 建立的Model對象是否 不可改變  即生成的Model對象不會有 setter方法划咐,只有構(gòu)造方法 -->
        <property name="immutable" value="false"/>
    </javaModelGenerator>

    <!--mapper映射文件生成所在的目錄 為每一個數(shù)據(jù)庫的表生成對應(yīng)的SqlMap文件 -->
    <!--<sqlMapGenerator targetPackage="mappers" targetProject=".\src\main\resources">-->
    <sqlMapGenerator targetPackage="mappers" targetProject="./src/main/resources">
        <property name="enableSubPackages" value="false"/>
    </sqlMapGenerator>

    <!-- 客戶端代碼,生成易于使用的針對Model對象和XML配置文件 的代碼
            type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper對象
            type="MIXEDMAPPER",生成基于注解的Java Model 和相應(yīng)的Mapper對象
            type="XMLMAPPER",生成SQLMap XML文件和獨立的Mapper接口
    -->

    <!-- targetPackage:mapper接口dao生成的位置 -->
    <!--<javaClientGenerator type="XMLMAPPER" targetPackage="com.mmall.dao" targetProject=".\src\main\java">-->
    <javaClientGenerator type="XMLMAPPER" targetPackage="com.mmall.dao" targetProject="./src/main/java">
        <!-- enableSubPackages:是否讓schema作為包的后綴 -->
        <property name="enableSubPackages" value="false" />
    </javaClientGenerator>


    <table tableName="mmall_shipping" domainObjectName="Shipping" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_cart" domainObjectName="Cart" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_cart_item" domainObjectName="CartItem" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_category" domainObjectName="Category" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_order" domainObjectName="Order" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_order_item" domainObjectName="OrderItem" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_pay_info" domainObjectName="PayInfo" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    <table tableName="mmall_product" domainObjectName="Product" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false">
        <columnOverride column="detail" jdbcType="VARCHAR" />
        <columnOverride column="sub_images" jdbcType="VARCHAR" />
    </table>
    <table tableName="mmall_user" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>


    <!-- geelynote mybatis插件的搭建 -->
</context>
</generatorConfiguration>

生成Mapper和POJO

  • 點擊右邊Maven Project
  • 展開Plugins
  • 展開mybatis-generator
  • 雙擊

Mybatis-plugin

  • 作用: 可以在dao 層 迅速找到對應(yīng)的XML

安裝

  • File-settings-Plugins-Browserepos 搜索Mybatis-plugin
  • 安裝

Mybatis-pagehelper分頁插件

PageHelper的優(yōu)點是钧萍,分頁和Mapper.xml完全解耦褐缠。實現(xiàn)方式是以插件的形式,對Mybatis執(zhí)行的流程進行了強化风瘦,添加了總數(shù)count和limit查詢队魏。屬于物理分頁

安裝

porm里面:

<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
  <version>4.1.0</version>
</dependency>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市弛秋,隨后出現(xiàn)的幾起案子器躏,更是在濱河造成了極大的恐慌,老刑警劉巖蟹略,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件登失,死亡現(xiàn)場離奇詭異,居然都是意外死亡挖炬,警方通過查閱死者的電腦和手機揽浙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來意敛,“玉大人馅巷,你說我怎么就攤上這事〔菀觯” “怎么了钓猬?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長撩独。 經(jīng)常有香客問我敞曹,道長账月,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任澳迫,我火速辦了婚禮局齿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘橄登。我一直安慰自己抓歼,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布拢锹。 她就那樣靜靜地躺著谣妻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪面褐。 梳的紋絲不亂的頭發(fā)上拌禾,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天,我揣著相機與錄音展哭,去河邊找鬼。 笑死闻蛀,一個胖子當(dāng)著我的面吹牛匪傍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播觉痛,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼役衡,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了薪棒?” 一聲冷哼從身側(cè)響起手蝎,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎俐芯,沒想到半個月后棵介,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡吧史,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年邮辽,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贸营。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡吨述,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出钞脂,到底是詐尸還是另有隱情揣云,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布冰啃,位于F島的核電站邓夕,受9級特大地震影響肋层,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜翎迁,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一栋猖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧汪榔,春花似錦蒲拉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至士聪,卻和暖如春锦援,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背剥悟。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工灵寺, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人区岗。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓略板,卻偏偏與公主長得像,于是被迫代替她去往敵國和親慈缔。 傳聞我的和親對象是個殘疾皇子叮称,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容