欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

浅谈Mybatis通用Mapper使用方法

程序员文章站 2024-04-01 18:55:52
对单表进行增删改查是项目中不可避免的需求,mybatis的通用mapper插件使这些操作变得简单 添加maven依赖 在对应工程的pom.xml文件中添加 &...

对单表进行增删改查是项目中不可避免的需求,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"/>
  <!--序列的获取规则,使用{num}格式化参数,默认值为{0}.nextval,针对oracle-->
  <!--可选参数一共3个,对应0,1,2,分别为sequencename,columnname,propertyname-->
  <property name="seqformat" value="{0}.nextval"/>
  <!--主键自增回写方法执行顺序,默认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>要求

实体类需要按照如下规则和数据库表进行转换,注解全部是jpa中的注解,所以我们在maven中添加了它的jar包依赖

  1. 表名默认使用类名,驼峰转下划线,如userinfo默认对应的表名为user_info
  2. 表名可以使用@table(name = "tablename")进行指定,对不符合第一条默认规则的可以通过这种方式指定表名
  3. 字段默认和@column一样,都会作为表字段,表字段默认为java对象的field名字驼峰转下划线形式
  4. 可以使用@column(name = "fieldname")指定不符合第3条规则的字段名
  5. 使用@transient注解可以忽略字段,添加该注解的字段不会作为表字段使用
  6. 建议一定是有一个@id注解作为主键的字段,可以有多个@id注解的字段作为联合主键
  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);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。