Mybatis-Plus 如何實現一對多關係 舉例 用戶與角色
- 2022 年 4 月 1 日
- 筆記
Mybatis-Plus 一對多Mybatis-Plus
不寫一句sql語句實現一對多
首先來看效果
Mysql資料庫
用戶表
角色表
用戶與角色的中間表
中間表如下
將三張表通過Mybatis Plus 的程式碼生成器生成到目錄下
Pojo
在User的Pojo 添加List
package com.zcx.pojo;
import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.format.annotation.DateTimeFormat;
import java.io.Serializable;
import java.math.BigInteger;
import java.util.Date;
import java.util.List;
/**
* @author zhaochangxin
* @date 2022/3/2 14:34
*/
// 生成getAndSet方法
@Data
// 有參
@AllArgsConstructor
// 無參
@NoArgsConstructor
@TableName("platform_usertest")
public class User implements Serializable {
// 默認自增欄位
@TableId(type = IdType.ASSIGN_ID)
private Long id;
// 用戶名
private String username;
// 密碼
private String password;
// 狀態
private int status;
// 創建者
@TableField("created_by")
private BigInteger createdBy;
// 創建時間
@DateTimeFormat(pattern = "yyyy-MM-dd hh:mm:ss")
// 欄位添加填充內容
@TableField(value = "created_date", fill = FieldFill.INSERT)
private Date createdDate;
// 最後修改者
@TableField("last_modified_by")
private BigInteger lastModifiedBy;
// 最後修改時間
@DateTimeFormat(pattern = "yyyy-MM-dd hh:mm:ss")
// 欄位添加填充內容
@TableField(value = "last_modified", fill = FieldFill.INSERT_UPDATE)
private Date lastModified;
// 所有者
private String owner;
// 樂觀鎖
@Version
private Integer version;
// 邏輯刪除
@TableLogic
private Integer deleted;
// 許可權
@TableField(exist = false)
private List<Role> roles;
}
IuserService
package com.zcx.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.zcx.pojo.User;
import java.util.List;
/**
* @author zhaochangxin
* @Title: IUserService
* @Package com.zcx.service
* @Description: IUserService
* @date 2022/3/30 17:21
*/
public interface IUserService extends IService<User> {
List<User> queryAllUser();
}
在ServiceImpl 實現該介面方法
package com.zcx.pojo;
import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.format.annotation.DateTimeFormat;
import java.io.Serializable;
import java.math.BigInteger;
import java.util.Date;
import java.util.List;
/**
* @author zhaochangxin
* @date 2022/3/2 14:34
*/
// 生成getAndSet方法
@Data
// 有參
@AllArgsConstructor
// 無參
@NoArgsConstructor
@TableName("platform_usertest")
public class User implements Serializable {
// 默認自增欄位
@TableId(type = IdType.ASSIGN_ID)
private Long id;
// 用戶名
private String username;
// 密碼
private String password;
// 狀態
private int status;
// 創建者
@TableField("created_by")
private BigInteger createdBy;
// 創建時間
@DateTimeFormat(pattern = "yyyy-MM-dd hh:mm:ss")
// 欄位添加填充內容
@TableField(value = "created_date", fill = FieldFill.INSERT)
private Date createdDate;
// 最後修改者
@TableField("last_modified_by")
private BigInteger lastModifiedBy;
// 最後修改時間
@DateTimeFormat(pattern = "yyyy-MM-dd hh:mm:ss")
// 欄位添加填充內容
@TableField(value = "last_modified", fill = FieldFill.INSERT_UPDATE)
private Date lastModified;
// 所有者
private String owner;
// 樂觀鎖
@Version
private Integer version;
// 邏輯刪除
@TableLogic
private Integer deleted;
// 許可權
@TableField(exist = false)
private List<Role> roles;
}
有問題或更好的辦法請留言告知,謝謝您的觀看。