欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis通用Mapper和PageHelper的過(guò)程詳解

 更新時(shí)間:2020年11月05日 14:55:04   作者:小白升職記  
這篇文章主要介紹了MyBatis通用Mapper和PageHelper的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

如果項(xiàng)目中使用到了MyBatis框架,那么使用通用Mapper和PageHelper分頁(yè)插件將極大的簡(jiǎn)化我們的操作。通用Mapper可以簡(jiǎn)化對(duì)單表的CRUD操作,PageHelper分頁(yè)插件可以幫我們自動(dòng)拼接分頁(yè)SQL,并且可以使用MyBatis Geneator來(lái)自動(dòng)生成實(shí)體類,Mapper接口和Mapper xml代碼,非常的方便。插件地址及作者鏈接https://gitee.com/free 。

引入依賴

這里使用Spring Boot來(lái)構(gòu)建,可參考Spring-Boot中使用Mybatis.html搭建一個(gè)Spring boot + MyBatis的框架,然后在pom中引入:

<!-- mybatis -->
<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>1.3.1</version>
</dependency>
<!-- 通用mapper -->
<dependency>
  <groupId>tk.mybatis</groupId>
  <artifactId>mapper-spring-boot-starter</artifactId>
  <version>1.1.5</version>
</dependency>
<!-- pagehelper 分頁(yè)插件 -->
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper-spring-boot-starter</artifactId>
  <version>1.2.3</version>
</dependency>

接著在pom中配置MyBatis Geneator:

<build>
  <plugins>
    <plugin>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-maven-plugin</artifactId>
      <version>1.3.5</version>
      <dependencies>
        <dependency>
          <!-- 數(shù)據(jù)庫(kù)連接驅(qū)動(dòng) -->
          <groupId>com.oracle</groupId>
          <artifactId>ojdbc6</artifactId>
          <version>6.0</version>
        </dependency>
        <dependency>
          <groupId>tk.mybatis</groupId>
          <artifactId>mapper</artifactId>
          <version>3.4.0</version>
        </dependency>
      </dependencies>
      <executions>
        <execution>
          <id>Generate MyBatis Artifacts</id>
          <phase>package</phase>
          <goals>
            <goal>generate</goal>
          </goals>
        </execution>
      </executions>
      <configuration>
        <!--允許移動(dòng)生成的文件 -->
        <verbose>true</verbose>
        <!-- 是否覆蓋 -->
        <overwrite>true</overwrite>
        <!-- 自動(dòng)生成的配置 -->
        <configurationFile>src/main/resources/mybatis-generator.xml</configurationFile>
      </configuration>
    </plugin>
  </plugins>
</build>

src/main/resources/mybatis-generator.xml為生成器的配置,下文會(huì)介紹到。

配置插件
在Spring Boot配置文件application.yml中配置MyBatis:

mybatis:
 # type-aliases掃描路徑
 type-aliases-package: com.springboot.bean
 # mapper xml實(shí)現(xiàn)掃描路徑
 mapper-locations: classpath:mapper/*.xml
 property:
  order: BEFORE

接下來(lái)開始配置插件。

配置通用Mapper
在Spring Boot配置文件application.yml中配置通用Mapper:

#mappers 多個(gè)接口時(shí)逗號(hào)隔開
mapper:
 mappers: com.springboot.config.MyMapper
 not-empty: false
 identity: oracle

關(guān)于參數(shù)的說(shuō)明,參考https://gitee.com/free/Mapper/blob/master/wiki/mapper3/2.Integration.md中的可配參數(shù)介紹。

除此之外,我們需要定義一個(gè)MyMapper接口:

import tk.mybatis.mapper.common.Mapper;
import tk.mybatis.mapper.common.MySqlMapper;

public interface MyMapper<T> extends Mapper<T>, MySqlMapper<T> {
	
}

值得注意的是,該接口不能被掃描到,應(yīng)該和自己定義的Mapper分開。自己定義的Mapper都需要繼承這個(gè)接口。

配置PageHelper
在Spring Boot配置文件application.yml中配置通用配置PageHelper:

#pagehelper
pagehelper: 
 helperDialect: oracle
 reasonable: true
 supportMethodsArguments: true
 params: count=countSql

參數(shù)相關(guān)說(shuō)明參考https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md中的分頁(yè)插件參數(shù)介紹。

配置Geneator*
在路徑src/main/resources/下新建mybatis-generator.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>
  <context id="oracle" targetRuntime="MyBatis3Simple" defaultModelType="flat">

    <plugin type="tk.mybatis.mapper.generator.MapperPlugin">
      <!-- 該配置會(huì)使生產(chǎn)的Mapper自動(dòng)繼承MyMapper -->
      <property name="mappers" value="com.springboot.config.MyMapper" />
      <!-- caseSensitive默認(rèn)false,當(dāng)數(shù)據(jù)庫(kù)表名區(qū)分大小寫時(shí),可以將該屬性設(shè)置為true -->
      <property name="caseSensitive" value="false"/>
    </plugin>

    <!-- 阻止生成自動(dòng)注釋 -->
    <commentGenerator>
      <property name="javaFileEncoding" value="UTF-8"/>
      <property name="suppressDate" value="true"/>
      <property name="suppressAllComments" value="true"/>
    </commentGenerator>

    <!-- 數(shù)據(jù)庫(kù)鏈接地址賬號(hào)密碼 -->
    <jdbcConnection 
      driverClass="oracle.jdbc.driver.OracleDriver"
      connectionURL="jdbc:oracle:thin:@localhost:1521:ORCL"
      userId="scott"
      password="6742530">
    </jdbcConnection>

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

    <!-- 生成Model類存放位置 -->
    <javaModelGenerator targetPackage="com.springboot.bean" 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類存放位置 -->
    <!-- 客戶端代碼,生成易于使用的針對(duì)Model對(duì)象和XML配置文件的代碼
      type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper對(duì)象
      type="XMLMAPPER",生成SQLMap XML文件和獨(dú)立的Mapper接口 -->
    <javaClientGenerator type="XMLMAPPER" targetPackage="com.springboot.mapper" targetProject="src/main/java">
      <property name="enableSubPackages" value="true"/>
    </javaClientGenerator>

    <!-- 配置需要生成的表 -->
    <table tableName="T_USER" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false">
      <generatedKey column="id" sqlStatement="oralce" identity="true"/>
    </table>
  </context>
</generatorConfiguration>

轉(zhuǎn)載:https://mrbird.cc/MyBatis%20common%20Mapper%20PageHelper.html

到此這篇關(guān)于MyBatis通用Mapper和PageHelper的文章就介紹到這了,更多相關(guān)MyBatis通用Mapper和PageHelper內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring中@ConditionalOnProperty注解的作用詳解

    Spring中@ConditionalOnProperty注解的作用詳解

    這篇文章主要介紹了Spring中@ConditionalOnProperty注解的作用詳解,@ConditionalOnProperty注解主要是用來(lái)判斷配置文件中的內(nèi)容來(lái)決定配置類是否生效用的,如果條件不匹配,則配置類不生效,需要的朋友可以參考下
    2024-01-01
  • java類型生命周期的詳細(xì)解析

    java類型生命周期的詳細(xì)解析

    以下是對(duì)java中的類型生命周期進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-08-08
  • spring設(shè)置定時(shí)任務(wù)方式(@Scheduled)

    spring設(shè)置定時(shí)任務(wù)方式(@Scheduled)

    這篇文章主要介紹了spring設(shè)置定時(shí)任務(wù)方式(@Scheduled),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Java-性能分析和監(jiān)控工具深入詳解

    Java-性能分析和監(jiān)控工具深入詳解

    這篇文章主要介紹了Java-性能分析和監(jiān)控工具深入詳解,文章內(nèi)容詳細(xì),簡(jiǎn)單易懂,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2023-01-01
  • 深入理解Java的Spring框架中的IOC容器

    深入理解Java的Spring框架中的IOC容器

    IOC(Inversion of Control,控制反轉(zhuǎn))是Spring框架的核心,負(fù)責(zé)控制對(duì)象的生命周期與關(guān)系,接下來(lái)就讓我們跟隨文章來(lái)深入理解Java的Spring框架中的IOC容器:
    2016-07-07
  • 10分鐘帶你理解Java中的反射

    10分鐘帶你理解Java中的反射

    反射是java中一種強(qiáng)大的工具,能夠使我們很方便的創(chuàng)建靈活的代碼,這篇文章帶大家十分鐘快速理解Java中的反射,有需要的可以參考借鑒。
    2016-08-08
  • java中Hibernate的狀態(tài)總結(jié)

    java中Hibernate的狀態(tài)總結(jié)

    在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于java中Hibernate的狀態(tài)總結(jié)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-01-01
  • 使用Feign調(diào)用時(shí)添加驗(yàn)證信息token到請(qǐng)求頭方式

    使用Feign調(diào)用時(shí)添加驗(yàn)證信息token到請(qǐng)求頭方式

    這篇文章主要介紹了使用Feign調(diào)用時(shí)添加驗(yàn)證信息token到請(qǐng)求頭方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java線程通信詳解

    Java線程通信詳解

    本篇文章主要介紹了Java線程通信問(wèn)題,線程通信用來(lái)保證線程協(xié)調(diào)運(yùn)行,有需要的朋友可以了解一下。
    2016-10-10
  • 一篇文章教帶你了解Java Spring之自動(dòng)裝配

    一篇文章教帶你了解Java Spring之自動(dòng)裝配

    今天小編就為大家分享一篇關(guān)于Spring中的自動(dòng)裝配,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2021-09-09

最新評(píng)論