【MyBatisPlus】DML编程控制
文章目录
- 【MyBatisPlus】DML编程控制
- 1、id生成策略
- 2、逻辑删除
1、id生成策略
id生成策略控制(@TableId注解)
-
名称:@TableId
-
类型:属性注解
-
位置:模型类中用于表示主键的属性定义上方
-
作用:设置当前类中主键属性的生成策略
-
相关属性
type:设置主键属性的生成策略,值参照IdType枚举值
针对每个公司,随着服务化演进,单个服务越来越多,数据库分的越来越细,有的时候一个业务需要分成好几个库,这时候自增主键或者序列之类的主键id生成方式已经不再满足需求,分布式系统中需要的是一个全局唯一的id生成规则。
具体的算法和代码,参见资料文件夹。
uuid生成的字符串,不是自增长,字符串作为主键查询速度,存储值是不连续的,查询慢
雪花算法:固定长度,全部数字(Long),增长的趋势,存储是连续的,查询速度快
@Data
@TableName("tbl_user")
public class User {
public User() {
}
public User(Long id, String name, String gender, String password, Integer age, String tel) {
this.id = id;
this.name = name;
this.gender = gender;
this.password = password;
this.age = age;
this.tel = tel;
}
//使用雪花算法
@TableId(type = IdType.ASSIGN_ID)
private Long id;
private String name;
private String gender;
@TableField("pwd")
private String password;
private Integer age;
private String tel;
}
全局策略配置
也可以在application.yml中进行全局的配置
- id-type 让所有表主键生成策略相同
- table-prefix 在每个实体类的前面添加相同的前缀
mybatis-plus:
global-config:
db-config:
id-type: assign_id
table-prefix: tbl_
2、逻辑删除
在实际环境中,如果想删除一条数据,是否会真的从数据库中删除该条数据?
-
删除操作业务问题:业务数据从数据库中丢弃
-
逻辑删除:为数据设置是否可用状态字段,删除时设置状态字段为不可用状态,数据保留在数据库中
假设一家公司,有人离职了,那他的信息被数据库清楚,但是,他做的合同业绩,需要被清楚吗
显然是不能的,所以我们在删除的时候,可以通过逻辑删除的方式
可以通过增加一列:deleted,当被删除的时候,将其设置为1,默认为0,
代码实现
修改表结构
-- 添加一列deleted,注意设置默认值为0
ALTER TABLE tbl_user ADD COLUMN deleted INT(1) DEFAULT 0;
-- 查看结构
DESC tbl_user;
1、数据库表中添加逻辑删除标记字段
2、实体类中添加对应字段,并设定当前字段为逻辑删除标记字段
@TableLogic包含以下属性
-
value:未删除时的值
-
delval:删除了的值
@Data
public class User {
private Long id;
//逻辑删除字段,标记当前记录是否被删除
@TableLogic
private Integer deleted;
}
3、配置逻辑删除字面值
mybatis-plus:
global-config:
db-config:
table-prefix: tbl_
# 逻辑删除字段名
logic-delete-field: deleted
# 逻辑删除字面值:未删除为0
logic-not-delete-value: 0
# 逻辑删除字面值:删除为1
logic-delete-value: 1
逻辑删除本质:逻辑删除的本质其实是修改操作。如果加了逻辑删除字段,查询数据时也会自动带上逻辑删除字段
@Test
void testLogicDeleted() {
int row = UserMapper.deleteById(5);
System.out.println(row + "条记录被逻辑删除");
}