Bootstrap

Mybatis-plus 双主键

一、首先引入依赖

在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;

   
}

七、问题解决:

458c654eceea41278539e7e0b57c48a7.png

出现这种错误,大概率是第一步加入的依赖版本冲突导致,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>

;