溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

淺談Mybatis通用Mapper使用方法

發(fā)布時間:2020-09-10 23:47:17 來源:腳本之家 閱讀:189 作者:就沒一個昵稱能用 欄目:編程語言

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

添加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">
  <!--================================================-->
  <!--可配置參數說明(一般無需修改)-->
  <!--================================================-->
  <!--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}格式化參數,默認值為{0}.nextval,針對Oracle-->
  <!--可選參數一共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ī)則和數據庫表進行轉換,注解全部是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);
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI