Mybatis学习之Mapper工具实践

本文介绍了一款用于Mybatis项目的通用Mapper插件,通过简单的配置即可实现基本的增删改查操作,并展示了如何使用Example对象进行复杂查询。文中还提到了实体类与数据库表映射的规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    最近使用了Mybatis开发项目,但是有个哥们引入了一个Mapper的插件,感觉像Hibernate的Template一样CURD全有。

   前言

获取该插件Maven语句

	<!--通用Mapper -->
		<dependency>
			<groupId>tk.mybatis</groupId>
			<artifactId>mapper</artifactId>
			<version>${mapper.version}</version>
		</dependency>

插件引入

import tk.mybatis.mapper.common.Mapper;

/**
 * 继承自己的MyMapper
 *
 * @author liuzh_3nofxnp
 * @since 2015-09-06 21:53
 */
public interface MyMapper<T> extends Mapper<T> {
	
}

插件使用

public interface TransInfoMapper extends MyMapper<TransInfo> {
Map<String,Object> getWechatAmountSum(Map<String,String> params);
int getTranInfoSeqNextVal();
int updateTransStatus(TransInfo transInfo);
}
增、删、改、查的基本已调过,最强大的功能:
Example example = new Example(TransInfo.class);
Example.Criteria criteria = example.createCriteria();
//no为实体类中的字段名称
criteria.andEqualTo("no", transNo);
int num = transInfoMapper.updateByExampleSelective(ti, example);

Mapper的使用注意事项:

实体类按照如下规则和数据库表进行转换,注解全部是JPA中的注解:

  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. 实体类可以继承使用,可以参考测试代码中的tk.mybatis.mapper.model.UserLogin2类.

  9. 由于基本类型,如int作为实体类字段时会有默认值0,而且无法消除,所以实体类中建议不要使用基本类型.

  10. @NameStyle注解,用来配置对象名/字段和表名/字段之间的转换方式,该注解优先于全局配置style,可选值:

  • normal:使用实体类名/属性名作为表名/字段名
  • camelhump:这是默认值,驼峰转换为下划线形式
  • uppercase:转换为大写
  • lowercase:转换为小写
如果你的实体类中包含了不是数据库表中的字段,你需要给这个字段加上@Transient注解,这样通用Mapper在处理单表操作时就不会将标注的属性当成表字段处理!

(具体参考wiki:https://github.com/abel533/Mapper/blob/master/wiki/mapper3/3.Use.md) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值