欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

淺談Mybatis通用Mapper使用方法

對單表進行增刪改查是項目中不可避免的需求,Mybatis的通用Mapper插件使這些操作變得簡單

我們提供的服務有:網(wǎng)站設計、做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、庫爾勒ssl等。為1000多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的庫爾勒網(wǎng)站制作公司

添加maven依賴

在對應工程的pom.xml文件中添加

<dependency>
  <groupId>javax.persistence</groupId>
  <artifactId>persistence-api</artifactId>
  <version>1.0</version>
</dependency>
<dependency>
  <groupId>tk.mybatis</groupId>
  <artifactId>mapper</artifactId>
  <version>3.1.2</version>
</dependency>

配置攔截器

在mybatis-config.xml文件中添加通用Mapper

<plugin interceptor="tk.mybatis.mapper.mapperhelper.MapperInterceptor">
  <!--================================================-->
  <!--可配置參數(shù)說明(一般無需修改)-->
  <!--================================================-->
  <!--UUID生成策略-->
  <!--配置UUID生成策略需要使用OGNL表達式-->
  <!--默認值32位長度:@java.util.UUID@randomUUID().toString().replace("-", "")-->
  <!--<property name="UUID" value="@java.util.UUID@randomUUID().toString()"/>-->
  <!--主鍵自增回寫方法,默認值MySQL,詳細說明請看文檔-->
  <property name="IDENTITY" value="HSQLDB"/>
  <!--序列的獲取規(guī)則,使用{num}格式化參數(shù),默認值為{0}.nextval,針對Oracle-->
  <!--可選參數(shù)一共3個,對應0,1,2,分別為SequenceName,ColumnName,PropertyName-->
  <property name="seqFormat" value="{0}.nextval"/>
  <!--主鍵自增回寫方法執(zhí)行順序,默認AFTER,可選值為(BEFORE|AFTER)-->
  <!--<property name="ORDER" value="AFTER"/>-->
  <!--通用Mapper接口,多個通用接口用逗號隔開-->
  <property name="mappers" value="tk.mybatis.mapper.common.Mapper"/>
</plugin>

繼承通用Mapper<T>,必須指定泛型<T>

public interface ClubMapper extends Mapper<TClub>
{

}

繼承了Mapper<T>之后,就擁有了Mapper中的各種通用方法,具體可以查看源碼

泛型(表對象實體類)<T>要求

實體類需要按照如下規(guī)則和數(shù)據(jù)庫表進行轉換,注解全部是JPA中的注解,所以我們在maven中添加了它的jar包依賴

  1. 表名默認使用類名,駝峰轉下劃線,如UserInfo默認對應的表名為user_info
  2. 表名可以使用@Table(name = "tableName")進行指定,對不符合第一條默認規(guī)則的可以通過這種方式指定表名
  3. 字段默認和@Column一樣,都會作為表字段,表字段默認為Java對象的Field名字駝峰轉下劃線形式
  4. 可以使用@Column(name = "fieldName")指定不符合第3條規(guī)則的字段名
  5. 使用@Transient注解可以忽略字段,添加該注解的字段不會作為表字段使用
  6. 建議一定是有一個@Id注解作為主鍵的字段,可以有多個@Id注解的字段作為聯(lián)合主鍵
  7. 默認情況下,實體類中如果不存在包含@Id注解的字段,所有的字段都會作為主鍵字段進行使用(這種效率極低)
  8. 實體類可以繼承使用
  9. 由于基本類型,如int作為實體類字段時會有默認值0,而且無法消除,所以實體類中建議不要使用基本類型

Mapper還提供了主鍵自增的方式

@Id
@GeneratedValue(generator = "JDBC")
@Column(name = "id")
private Integer id;

添加Mapper配置

將繼承的Mapper接口添加到mybatis-config.xml文件中

<mappers>
  <mapper class="com.ind4.iss.icp.dao.logic.map.mapper.club.clubMapper" />
</mappers>

具體使用

public List<TClub> queryList() throws CcpException
{
  SqlSession sqlSession = CcpDB.getInstance().getSession();

  try
  {
    ClubMapper mapper = getMapper(sqlSession);
    TClub tClub = new TClub();
    return mapper.select(tClub);
  }
  catch (Exception e)
  {
    CcpLogger.getInstance().error(e, "TClubDAO.queryList, status=" + status);
    throw new CcpException(CcpErrorCode.ERROR_CLUB_DAO_DB_ERROR, e);
  }
  finally
  {
    CcpDB.getInstance().closeSession();
  }
}

private ClubMapper getMapper(SqlSession sqlSession)
{
  return sqlSession.getMapper(ClubMapper.class);
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

分享標題:淺談Mybatis通用Mapper使用方法
轉載來于:http://www.chinadenli.net/article18/piijgp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名小程序開發(fā)網(wǎng)站內(nèi)鏈品牌網(wǎng)站制作網(wǎng)站制作企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站