java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Mybatis-plus 双主键

Mybatis-plus 双主键的实现示例

作者:0000it_

本文主要介绍了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>

到此这篇关于Mybatis-plus 双主键的实现示例的文章就介绍到这了,更多相关Mybatis-plus 双主键内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文