前言

在Java世界中,我们经常处理的一个问题就是如何有效地与数据库进行交互。对此,许多不同的框架和库已经被开发出来,包括广为人知的MyBatis。然而,MyBatis虽然功能强大,但在实际使用中,我们常常需要写大量的XML配置和DAO代码,这无疑增加了开发的复杂性。这时,一个名为MyBatisPlus的库闯入了我们的视线。那么,MyBatisPlus是什么?它与MyBatis有什么区别和联系?本文将详细地解答这些问题。

1. MyBatisPlus简介

MyBatisPlus(简称MP)是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生。它引入了一些新的特性,如自动填充、乐观锁插件、逻辑删除等,同时还内置了一些常用的CRUD操作,极大地减少了开发人员的工作量。

2. MyBatisPlus与MyBatis的联系

MyBatisPlus是基于MyBatis的,因此,它们之间存在着紧密的联系。MyBatisPlus继承了MyBatis的所有特性,包括动态SQL、SQL注入器、分页插件等。同时,MyBatisPlus还兼容MyBatis的所有配置和使用习惯,使得开发人员可以无缝地从MyBatis迁移到MyBatisPlus。

3. MyBatisPlus与MyBatis的区别

虽然MyBatisPlus基于MyBatis,但它并非只是MyBatis的复制品。MyBatisPlus在MyBatis的基础上做了很多增强和优化,使得它在某些方面超过了MyBatis。以下是MyBatisPlus与MyBatis的主要区别:

1. 无需手写SQL

在MyBatis中,如果我们需要执行CRUD操作,通常需要手动编写SQL语句。而在MyBatisPlus中,我们可以直接调用内置的方法来完成这些操作,而无需手动编写SQL。例如,我们可以使用BaseMapper接口中的insertselectByIdupdateByIddeleteById方法来完成插入、查询、更新和删除操作。

User user = new User();
user.setName("John");
user.setEmail("john@example.com");
// 插入操作,无需手写SQL
userMapper.insert(user);

// 查询操作,无需手写SQL
User userFromDb = userMapper.selectById(user.getId());

// 更新操作,无需手写SQL
userFromDb.setAge(31);
userMapper.updateById(userFromDb);

// 删除操作,无需手写SQL
userMapper.deleteById(userFromDb.getId());

MyBatisPlus 提供了 IService 接口,这个接口封装了一些常见的 CRUD 操作,比如 save()remove()update()list() 等等。如果你的 service 类实现了这个接口,那么你就可以直接在 service 类中调用这些方法,而不需要再去调用 mapper 的方法。这样可以使得你的 service 类更加简洁,也更加符合面向对象的设计原则。

例如:

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {
    // ...
}

// 在 controller 或其他地方使用
@Autowired
private IUserService userService;

public void someMethod() {
    User user = new User();
    user.setName("John");
    user.setEmail("john@example.com");

    // 直接调用 service 的方法,而不需要调用 mapper 的方法
    userService.save(user);
}

而在 MyBatis 中,你通常需要在 service 类中注入 mapper,然后通过调用 mapper 的方法来进行数据库操作,例如:

@Service
public class UserServiceImpl implements IUserService {
    private final UserMapper userMapper;

    public UserServiceImpl(UserMapper userMapper) {
        this.userMapper = userMapper;
    }

    // ...

    public void someMethod() {
        User user = new User();
        user.setName("John");
        user.setEmail("john@example.com");

        // 需要调用 mapper 的方法来进行数据库操作
        userMapper.insert(user);
    }
}

2. 自动填充功能

MyBatisPlus支持自动填充功能,我们可以通过在实体类中使用@TableField(fill = FieldFill.INSERT)@TableField(fill = FieldFill.UPDATE)注解来指定哪些字段需要在插入或更新时自动填充。

public class User implements Serializable {
    // ...

    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(fill = FieldFill.UPDATE)
    private Date updateTime;

    // ...
}

3. 乐观锁插件

MyBatisPlus内置了乐观锁插件,我们可以通过在实体类中使用@Version注解来指定哪个字段作为乐观锁字段。

public class User implements Serializable {
    // ...

    @Version
    private Integer version;

    // ...
}

然后在更新时,MyBatisPlus会自动将版本号加一,并在更新语句中添加版本号的判断条件。

4. 逻辑删除

MyBatisPlus支持逻辑删除,我们可以通过在实体类中使用@TableLogic注解来指定哪个字段作为逻辑删除字段。

public class User implements Serializable {
    // ...

    @TableLogic
    private Integer deleted;

    // ...
}

然后在执行删除操作时,MyBatisPlus会自动将逻辑删除字段的值更新为删除标记,而不是真正地删除记录。

5. 性能分析插件

MyBatisPlus内置了性能分析插件,我们可以通过配置该插件来启用SQL性能分析。

@Configuration
public class MybatisPlusConfig {

    @Bean
    public PerformanceInterceptor performanceInterceptor() {
        PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
        // 设置SQL性能分析的最大时间,如果超过这个时间,则不执行
        performanceInterceptor.setMaxTime(1000);
        // 设置SQL格式化
        performanceInterceptor.setFormat(true);
        return performanceInterceptor;
    }

}

然后该插件会自动输出每条SQL语句的执行时间,如果超过设定的最大时间,则不执行该SQL。

4. MyBatisPlus的使用示例

下面,我们将通过一个简单的例子来演示如何使用MyBatisPlus。假设我们有一个用户表(user),现在我们想要实现对该表的CRUD操作。

首先,我们需要创建一个User实体类:

import com.baomidou.mybatisplus.annotation.*;
import java.io.Serializable;
import java.util.Date;

public class User implements Serializable {
    private static final long serialVersionUID = 1L;

    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    private String name;

    private Integer age;

    private String email;

    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(fill = FieldFill.UPDATE)
    private Date updateTime;

    @Version
    private Integer version;

    @TableLogic
    private Integer deleted;

    // getters and setters...
}

然后,我们需要创建一个UserMapper接口:

import com.baomidou.mybatisplus.core.mapper.BaseMapper;

public interface UserMapper extends BaseMapper<User> {

}

最后,我们就可以使用MyBatisPlus进行CRUD操作了:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public void crudOperations() {
        // 创建一个新用户
        User user = new User();
        user.setName("John");
        user.setAge(30);
        user.setEmail("john@example.com");
        userMapper.insert(user);

        // 查询用户
        User userFromDb = userMapper.selectById(user.getId());
        System.out.println(userFromDb);

        // 更新用户
        userFromDb.setAge(31);
        userMapper.updateById(userFromDb);

        // 删除用户
        userMapper.deleteById(userFromDb.getId());
    }
}

5. 结论

MyBatisPlus是一个强大的MyBatis增强工具,它继承了MyBatis的所有特性,同时还引入了一些新的特性,如自动填充、乐观锁插件、逻辑删除等。通过使用MyBatisPlus,开发人员可以大大减少手写SQL的工作量,提高开发效率。如果你正在使用MyBatis,那么不妨试试MyBatisPlus,相信它会给你带来全新的开发体验。

👉 💐🌸 公众号请关注 "果酱桑", 一起学习,一起进步! 🌸💐

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐