浅谈Mybatis通用Mapper使用方法

作者:就没一个昵称能用 时间:2023-02-15 17:46:52 

对单表进行增删改查是项目中不可避免的需求,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);
}

来源:http://www.jianshu.com/p/5854bfd0f0e6?utm_source=tuicool&utm_medium=referral

标签:Mybatis,Mapper
0
投稿

猜你喜欢

  • sin(x)如何求解的java代码实现方法

    2022-04-17 16:22:07
  • android实现扑克卡片翻转

    2021-10-19 08:08:35
  • C#实现身份证号码验证的方法

    2022-11-08 09:15:34
  • C#中new的几种用法详解

    2021-09-16 23:05:56
  • java求数组元素重复次数和java字符串比较大小示例

    2023-08-04 22:20:02
  • Spring整合Quartz实现动态定时器的示例代码

    2022-10-22 06:48:17
  • Java源码解析LinkedList

    2023-04-28 02:56:18
  • Android Shader应用开发之霓虹闪烁文字效果

    2022-09-11 16:43:20
  • Android自定义控件实现优雅的广告轮播图

    2023-01-14 22:15:51
  • Android通过ExifInterface判断Camera图片方向的方法

    2023-02-02 18:43:38
  • Android Universal ImageLoader 缓存图片

    2023-03-04 05:16:54
  • Java线程的生命周期的详解

    2022-05-18 00:32:08
  • SpringBoot2 实现JPA分页和排序分页的案例

    2022-02-23 13:26:08
  • C#实现json格式转换成对象并更换key的方法

    2021-12-23 00:09:39
  • Android Fragment概述及用法

    2022-08-23 15:54:22
  • 浅谈JDK8中的Duration Period和ChronoUnit

    2023-01-07 20:10:01
  • servlet异步请求的实现

    2023-07-14 17:11:38
  • javamail 发送邮件的实例代码分享

    2021-12-22 15:10:47
  • Spring Boot 中application.yml与bootstrap.yml的区别

    2023-07-09 12:30:56
  • 源码浅析Android中内存泄漏检测工具Leakcanary的使用

    2021-11-02 12:30:11
  • asp之家 软件编程 m.aspxhome.com