当前位置:实例文章 » JAVA Web实例» [文章]【MyBatis-Plus 进阶学习笔记】

【MyBatis-Plus 进阶学习笔记】

发布人:shili8 发布时间:2025-02-24 15:54 阅读次数:0

**MyBatis-Plus 进阶学习笔记**

前言----

MyBatis-Plus 是一个基于 MyBatis 的 ORM 框架,它提供了许多高级特性,如 CRUD 操作、分页功能、缓存机制等。通过阅读本文档,你将能够深入了解 MyBatis-Plus 的各个方面,并掌握如何使用它来提高你的开发效率。

**一、基本概念**

###1.1 MyBatis-Plus 的核心类MyBatis-Plus 的核心类有以下几个:

* `Mapper`:这是 MyBatis-Plus 中最重要的一个接口,它定义了 CRUD 操作的方法。
* `SqlSession`:这是 MyBatis-Plus 中负责执行 SQL语句的类。
* `Configuration`:这是 MyBatis-Plus 中配置文件的类。

###1.2 Mapper 接口Mapper 接口是 MyBatis-Plus 中最重要的一个接口,它定义了 CRUD 操作的方法。例如,以下是一个简单的 UserMapper 接口:

javapublic interface UserMapper extends Mapper {
 @Select("SELECT * FROM user WHERE id = #{id}")
 List selectById(@Param("id") Long id);
}


在这个例子中,我们定义了一个 `selectById` 方法,它根据 ID 查询用户信息。

###1.3 SqlSessionSqlSession 是 MyBatis-Plus 中负责执行 SQL语句的类。例如,以下是一个简单的使用 SqlSession 的例子:

javapublic class Test {
 @Test public void test() {
 // 创建一个 SqlSession 对象 SqlSession sqlSession = new SqlSession();
 // 使用 SqlSession 执行 SQL语句 List users = sqlSession.selectList("UserMapper.selectById",1L);
 // 打印结果 System.out.println(users);
 }
}


在这个例子中,我们创建了一个 SqlSession 对象,然后使用它执行 SQL语句。

###1.4 ConfigurationConfiguration 是 MyBatis-Plus 中配置文件的类。例如,以下是一个简单的配置文件:

xml<configuration>
 <environments default="development">
 <environment id="development">
 <transactionManager type="JDBC"/>
 <dataSource type="POOLED">
 <property name="driver" value="${jdbc.driver}"/>
 <property name="url" value="${jdbc.url}"/>
 <property name="username" value="${jdbc.username}"/>
 <property name="password" value="${jdbc.password}"/>
 </dataSource>
 </environment>
 </environments>
 <mappers>
 <mapper class="com.example.UserMapper"/>
 </mappers>
</configuration>


在这个例子中,我们定义了一个配置文件,包含了环境、事务管理器和数据源的设置。

**二、CRUD 操作**

###2.1 insertinsert 是 MyBatis-Plus 中用于插入新记录的方法。例如,以下是一个简单的使用 insert 的例子:

javapublic class Test {
 @Test public void test() {
 // 创建一个 User 对象 User user = new User();
 // 设置属性值 user.setId(1L);
 user.setName("张三");
 // 使用 MyBatis-Plus 插入新记录 int result = userMapper.insert(user);
 // 打印结果 System.out.println(result);
 }
}


在这个例子中,我们创建了一个 User 对象,然后使用 MyBatis-Plus 插入新记录。

###2.2 updateupdate 是 MyBatis-Plus 中用于更新已有记录的方法。例如,以下是一个简单的使用 update 的例子:

javapublic class Test {
 @Test public void test() {
 // 创建一个 User 对象 User user = new User();
 // 设置属性值 user.setId(1L);
 user.setName("张三");
 // 使用 MyBatis-Plus 更新已有记录 int result = userMapper.update(user);
 // 打印结果 System.out.println(result);
 }
}


在这个例子中,我们创建了一个 User 对象,然后使用 MyBatis-Plus 更新已有记录。

###2.3 deletedelete 是 MyBatis-Plus 中用于删除已有记录的方法。例如,以下是一个简单的使用 delete 的例子:

javapublic class Test {
 @Test public void test() {
 // 使用 MyBatis-Plus 删除已有记录 int result = userMapper.delete(1L);
 // 打印结果 System.out.println(result);
 }
}


在这个例子中,我们使用 MyBatis-Plus 删除已有记录。

**三、分页功能**

###3.1 PageHelperPageHelper 是 MyBatis-Plus 中用于实现分页功能的类。例如,以下是一个简单的使用 PageHelper 的例子:

javapublic class Test {
 @Test public void test() {
 // 使用 PageHelper 分页查询 Page page = PageHelper.startPage(1,10);
 // 查询数据 List users = userMapper.selectList(null);
 // 打印结果 System.out.println(page.getTotal());
 System.out.println(users);
 }
}


在这个例子中,我们使用 PageHelper 分页查询。

###3.2 PageInfoPageInfo 是 MyBatis-Plus 中用于实现分页功能的类。例如,以下是一个简单的使用 PageInfo 的例子:

javapublic class Test {
 @Test public void test() {
 // 使用 PageInfo 分页查询 PageInfo pageInfo = new PageInfo<>(userMapper.selectList(null));
 // 打印结果 System.out.println(pageInfo.getTotal());
 System.out.println(pageInfo.getList());
 }
}


在这个例子中,我们使用 PageInfo 分页查询。

**四、缓存机制**

###4.1 CacheCache 是 MyBatis-Plus 中用于实现缓存功能的类。例如,以下是一个简单的使用 Cache 的例子:

javapublic class Test {
 @Test public void test() {
 // 使用 Cache 缓存数据 int result = userMapper.selectCount(null);
 // 打印结果 System.out.println(result);
 }
}


在这个例子中,我们使用 Cache 缓存数据。

###4.2 RedisRedis 是 MyBatis-Plus 中用于实现缓存功能的类。例如,以下是一个简单的使用 Redis 的例子:

javapublic class Test {
 @Test public void test() {
 // 使用 Redis 缓存数据 int result = userMapper.selectCount(null);
 // 打印结果 System.out.println(result);
 }
}


在这个例子中,我们使用 Redis 缓存数据。

**五、总结**

MyBatis-Plus 是一个基于 MyBatis 的 ORM 框架,它提供了许多高级特性,如 CRUD 操作、分页功能、缓存机制等。通过阅读本文档,你将能够深入了解 MyBatis-Plus 的各个方面,并掌握如何使用它来提高你的开发效率。

**参考**

* [MyBatis-Plus 官方文档]( />* [MyBatis-Plus GitHub仓库](

其他信息

其他资源

Top