小书MybatisPlus第5篇-Active Record模式精讲

举报
字母哥哥 发表于 2022/04/15 00:48:16 2022/04/15
【摘要】 本文为一个系列中的第五节,前四节访问如下地址: 小书MybatisPlus第1篇-整合SpringBoot快速开始增删改查小书MybatisPlus第2篇-条件构造器的应用及总结小书MybatisPlu...

本文为一个系列中的第五节,前四节访问如下地址:

Active Record 适合非常简单的领域需求,尤其在领域模型和数据库模型十分相似的情况下。如果遇到更加复杂的领域模型结构(例如用到继承、策略的领域模型),往往需要使用分离数据源的领域模型,结合 Data Mapper (数据映射器)使用。

具体到使用层面,我们之前章节讲过使用Data Mapper 做数据的持久层操作。

User user = new User();
user.setName("字母哥");
user.setAge(18);

userMapper.insert(user);   //Mybatis Mapper模式

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

现在我们使用ActiveRecord模式,用法如下,注意二者的区别

User user = new User();
user.setName("zimug");
user.setAge(18);

user.insert();  //ActiveRecord模式

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

一、使ActiveRecord模式生效

首先:需要让数据库表对应的数据持久层实体类。集成自Model,并实现序列化接口。

@Data   //lombok注解
@EqualsAndHashCode(callSuper = true)
public class User extends Model<User> implements Serializable {
    private static final long serialVersionUID = 6401942840459021558L;
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

其实定义一个Mapper继承自BaseMapper<T>,T代表数据持久层实体类。

public interface UserMapper extends BaseMapper<User> {
}

  
 
  • 1
  • 2

这样Mybatis Plus的ActiveRecord模式就生效了,默认的帮我们实现了如下的一些数据持久层方法。
Mybatis Plus的ActiveRecord模式方法

二、增删该查的实现

增加:向持久层实体类User对应的数据库表user,插入一条数据。

@Test
public void testInsert() {
  User user = new User();
  user.setName("zimug");
  user.setAge(18);
  user.setEmail("hadoopcn2@163.com");

  boolean success = user.insert();
  System.out.println("是否插入成功:"+success);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

查询:从数据库表user查询所有数据


@Test
public void testSelect() {
  User user = new User();
  List<User> users = user.selectAll();
  users.forEach(System.out::println);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

添加或更新:

  • 未设置ID,被视为insert操作,向数据库插入数据
  • 如果设置ID,则先查询是否有此id的记录,如果有此id记录,则视为update,如果没有则视为insert
@Test
public void testUpdate() {
  User user = new User();
  user.setId(1283915378849751041L);
  user.setAge(25);

  boolean success = user.insertOrUpdate();
  System.out.println("是否添加或更新成功(更新):"+success);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

根据id在数据库表user中删除一条记录

@Test
public void testDelete() {
  User user = new User();
  user.setId(1283915378849751041L);

  boolean success = user.deleteById();
  System.out.println("是否删除成功:"+success);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

文章来源: zimug.blog.csdn.net,作者:字母哥哥,版权归原作者所有,如需转载,请联系作者。

原文链接:zimug.blog.csdn.net/article/details/107399925

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。