一、首先引入依赖
在Maven工程下的pom.xml文件引入这两个依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>com.github.jeffreyning</groupId>
<artifactId>mybatisplus-plus</artifactId>
<version>1.5.1-RELEASE</version>
</dependency>
二、在启动类中添加@EnableMpp标签
package com.GradeSystem.app;
import com.github.jeffreyning.mybatisplus.conf.EnableMPP;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
// web工程的启动类 该类启动一个内置的tomcat服务器
@SpringBootApplication //启动web服务器的注解标签
@MapperScan("com.GradeSystem.app.dao")
@EnableMPP
public class SpringBootApp {
public static void main(String[] args) {
SpringApplication.run(SpringBootApp.class);//启动内置tomcat服务器
}
}
三、在实体类中添加@MppMultiId标签和@TableField
package com.GradeSystem.app.bean;
import com.baomidou.mybatisplus.annotation.*;
import com.baomidou.mybatisplus.extension.activerecord.Model;
import com.github.jeffreyning.mybatisplus.anno.MppMultiId;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
/**
* 功能:
* 作者:jiaping
* 日期:2023/9/5 20:48
**/
@Data //注解标签在类的头部编写,生成get set 无参数一有参数和其它的方法
@AllArgsConstructor //会自动生成有参数构造函数
@NoArgsConstructor //会生成无参构造函数
public class Grade implements Serializable {
@MppMultiId
@TableField(value = "stuid")
private String stuid; // 学生学号
@MppMultiId
@TableField(value = "counum")
private String counum;//课程序号
private String classid;//行政班级
private Float ordinaryscore;//平时成绩
private Float labscore;//实验成绩
private Float finalscore;//期末成绩
private Float finalgrade;//总评成绩
private String gradepoint;//绩点
private String pass;//是否通过
private String stus;//状态
private String resitgrade;//补考成绩
@TableField(exist = false) //非数据库字段
private String stuname;//学生姓名
}
四、在控制器类中添加复合主键操作,批量更新
/**
* 功能:
* 作者:jiaping
* 日期:2023/9/5 20:54
**/
@Api(tags = "成绩表")
@RestController //具备请求和相应功能
@RequestMapping("/grade")
@CrossOrigin //跨域访问
public class GradeController {
@Autowired
private GradeService gradeService;
@PostMapping("/batchSave")
public CommonResult batchSave(@RequestBody List<Grade> product) {
// 进行批量保存操作,例如批量保存到数据库
return CommonResult.success(gradeService.saveOrUpdateBatchByMultiId(product));
}
}
五、Mapper或者Dao类继承@MppBaseMapper
@Repository //表示这是数据访问层标签,意思就是将数据存储到数据库中,是springboot他的语义化注解标签
public interface GradeDao extends MppBaseMapper<Grade> {
}
六、Service和ServiceImpl类继承IMppService和MppServiceImpl
public interface GradeService extends IMppService<Grade> {
}
@Service
public class GradeServiceImpl extends MppServiceImpl<GradeDao, Grade> implements GradeService {
@Autowired //用来实例化对象
private GradeDao gradeDao;
}
七、问题解决:
出现这种错误,大概率是第一步加入的依赖版本冲突导致,mybatisplus-plus的版本1.5.1不要和mybatis-plus-boot-starter的版本3.5.2一起使用,更换为3.4.0
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>com.github.jeffreyning</groupId>
<artifactId>mybatisplus-plus</artifactId>
<version>1.5.1-RELEASE</version>
</dependency>