万普插件库

jQuery插件大全与特效教程

MyBatis-Plus 比 MyBatiskuai快多少

一、MyBatis 与 MyBatis-Plus 概述

1. MyBatis

MyBatis 是一款优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的操作。其核心思想是通过 XML 或注解 将 SQL 语句与 Java 方法映射,实现 SQL 与业务逻辑的分离,同时支持自定义 SQL、存储过程和高级映射。

2. MyBatis-Plus(MP)

MyBatis-Plus 是 MyBatis 的增强工具(只做增强,不做改变),在 MyBatis 基础上简化了开发流程,提供了一系列开箱即用的功能(如 CRUD 接口、条件构造器等),无需编写重复 SQL,大幅提升开发效率。

二、核心功能对比

三、架构关系图(示意图描述)

四、代码示例对比

1. 基础 CRUD 操作

MyBatis 实现:

需手动编写 Mapper 接口和 XML 映射文件。

  • 实体类 User.java

public class User {

private Long id;

private String name;

private Integer age;

// getter/setter

}

  • Mapper 接口 UserMapper.java

public interface UserMapper {

// 查询所有用户

List<User> selectAll();

// 新增用户

int insert(User user);

// 根据 ID 删除

int deleteById(Long id);

}

  • XML 映射文件 UserMapper.xml

<mapper namespace="com.example.mapper.UserMapper">

<!-- 查询所有 -->

<select id="selectAll" resultType="com.example.entity.User">

SELECT id, name, age FROM user

</select>

<!-- 新增 -->

<insert id="insert" parameterType="com.example.entity.User">

INSERT INTO user (name, age) VALUES (#{name}, #{age})

</insert>

<!-- 删除 -->

<delete id="deleteById" parameterType="java.lang.Long">

DELETE FROM user WHERE id = #{id}

</delete>

</mapper>

MyBatis-Plus 实现:

继承 BaseMapper 接口,无需编写 SQL。

o Mapper 接口 UserMapper.java

public interface UserMapper extends BaseMapper<User> {

// 无需写方法,BaseMapper 已包含 selectList()、insert()、deleteById() 等

}

  • 调用示例

@Autowired

private UserMapper userMapper;

// 查询所有

List<User> userList = userMapper.selectList(null);

// 新增

User user = new User();

user.setName("张三");

user.setAge(20);

userMapper.insert(user);

// 根据 ID 删除

userMapper.deleteById(1L);

2. 条件查询

MyBatis 实现:

需用动态 SQL 标签拼接条件。

oXML 映射文件新增

<select id="selectByCondition" parameterType="map" resultType="User">

SELECT id, name, age FROM user

<where>

<if test="name != null">AND name LIKE CONCAT('%', #{name}, '%')</if>

<if test="age != null">AND age > #{age}</if>

</where>

</select>

MyBatis-Plus 实现:

用 QueryWrapper 链式组装条件。

// 查询:name 包含"张"且 age > 18 的用户

QueryWrapper<User> queryWrapper = new QueryWrapper<>();

queryWrapper.like("name", "张") // LIKE '%张%'

.gt("age", 18); // age > 18

List<User> userList = userMapper.selectList(queryWrapper);

3. 分页查询

MyBatis 实现(需集成 PageHelper):

// 配置 PageHelper 插件(省略配置类)

PageHelper.startPage(1, 10); // 第1页,每页10条

List<User> userList = userMapper.selectAll();

Page<User> page = (Page<User>) userList;

MyBatis-Plus 实现:

// 1. 配置分页插件(Spring Boot 配置类)

@Configuration

public class MyBatisPlusConfig {

@Bean

public MybatisPlusInterceptor mybatisPlusInterceptor() {

MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();

// 添加分页插件

interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));

return interceptor;

}

}

// 2. 分页查询

Page<User> page = new Page<>(1, 10); // 第1页,每页10条

IPage<User> userPage = userMapper.selectPage(page, null);

List<User> records = userPage.getRecords(); // 数据列表

long total = userPage.getTotal(); // 总条数

五、总结

o MyBatis:灵活性高,适合需要高度自定义 SQL 的场景,但需编写大量重复代码。

o MyBatis-Plus:在 MyBatis 基础上简化开发,提供丰富的增强功能,适合快速开发(尤其是 CRUD 密集型业务)。

实际开发中,两者可无缝结合:简单操作用 MP 简化,复杂 SQL 仍可通过 MyBatis 的 XML/注解实现。

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言