在实际的生产过程中,某些业务场景会用到复合主键来标识唯一性。但是mybatisPlus亦或mybatis都不默认支持对复合主键的操作。刚好再一次实际的数据项目中遇到这个需求了,记录下来。
# 1、首先是导入项目的依赖
这里使用maven管理依赖,依赖于mybatis-plus有版本关联,使用的时候注意区分。
# 2、业务实体的复合主键配置
这里区不使用` @TableId`,复合主键使用注解 ` @MppMultiId ` 和 `@TableField` 来标识实体主键,如:
```
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.github.jeffreyning.mybatisplus.anno.MppMultiId;
@TableName("feeinfo")
public class EaJcFeeinfo {
@MppMultiId
@TableField(value = "orgbusno")
private String orgbusno;
@MppMultiId
@TableField(value = "projid")
private String projid;
@MppMultiId
@TableField(value = "dataver")
private Integer dataver;
}
```
注意 `@TableField(value = "projid")` 中的value值为主键的字段名称,注意不要弄错了。
# 3、Dao层的实现
这里区别于mybatis或mybatisplus,需要继承的是
`MppBaseMapper`
例如:
```
import com.github.jeffreyning.mybatisplus.base.MppBaseMapper;
public interface EaJcFeeinfoDao extends MppBaseMapper
}
```
# 4、service层的实现
同样和通常的实现项不同,这个service接口需要继承的是`
IMppService
`
实现类需要继承的是 `
MppServiceImpl
`
例如:
service接口:
```
import com.github.jeffreyning.mybatisplus.service.IMppService;
public interface EaJcFeeinfoService extends IMppService
}
```
service接口实现:
```
import com.github.jeffreyning.mybatisplus.service.MppServiceImpl;
@Service("eaJcFeeinfoService")
public class EaJcFeeinfoServiceImpl extends MppServiceImpl
}
```
# 5、项目开启复合主键
完成上述的关键配置后,还需要开启用复合主键,这里使用 `@EnableMPP`注解开启,配置在项目启动类上,如:
```
import com.github.jeffreyning.mybatisplus.conf.EnableMPP;
@SpringBootApplication
@EnableMPP
public class SpringbootApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(SpringbootApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(SpringbootApplication.class);
}
}
```
上面的依赖、实体、接口、实现类、注解 配置完成后,就可以正常的使用复合主键进行业务开发了。~ —— ~