MyBatis学习笔记

MyBatis是Java领域中的一款持久化框架,它的主要功能是,让我们能够轻松地在Java对象和数据库之间建立联系。

MyBatis的核心组件

首先第一个是,SqlSessionFactory,它就像是一个会话工厂。它的任务是创建 SqlSession 对象,这个对象是我们与数据库交互的主要途径。SqlSessionFactory 的作用很重要,因为它可以帮我们配置数据库连接信息和事务管理等。一旦这个工厂被建立起来,它就会加载一些必要的配置和映射文件,为后续的数据库操作提供一个可靠的基础。

第二个是 SqlSession,可以理解为我们与数据库进行互动的窗口。通过它,我们能够执行 SQL 语句,提交或回滚事务,还可以获取 Mapper 接口的实例。不过需要注意的是,SqlSession 的生命周期是短暂的,通常在数据库操作完成后就应该关闭它,这样可以释放资源。

接下来是 Mapper 接口,这个概念有点像定义了一套数据库操作的规则。每个 Mapper 接口对应一个或多个映射文件,里面的方法定义了具体的 SQL 操作,比如插入、更新、删除和查询等。MyBatis 通过动态代理的方式,把接口方法和映射文件中的 SQL 语句关联起来,这样我们就可以方便地通过接口来执行数据库操作。

最后,是映射文件,它是一个用来连接 Java 对象和数据库表的桥梁。在映射文件里,我们可以定义 SQL 语句、参数映射、结果映射等等。里面的 SQL 语句可以包括增删改查等操作,MyBatis 会根据我们调用的方法来选择正确的 SQL 语句来执行。、

MyBatis一二级缓存的区别?

一级缓存。在同一个会话里,MyBatis 会自动开启一级缓存。这个缓存就是为了优化查询操作的速度。一旦你执行了一个查询,MyBatis 会把结果先存起来,这样下次再查询相同的数据的时候,它就可以直接从缓存里拿,不用再去数据库查询了。只要会话不结束,这个缓存就一直有效,只在这一个会话里起作用。

二级缓存。这个缓存是用来跨会话共享数据的。不同的会话也能分享同样的缓存数据,这就意味着可以减少数据库的访问次数。不过,二级缓存需要手动配置开启,然后它可以把数据存到更持久的存储地方,比如文件系统或者分布式缓存里。这样多个会话就可以共享同样的缓存数据了。

一级缓存只在一个会话内部有效,而二级缓存可以在不同会话之间共享数据。其次,一级缓存默认就是开启的,不需要特别设置。但是二级缓存需要你手动配置才能生效。然后就是数据共享性,因为一级缓存只在会话内有效,所以不同的会话无法共享缓存数据。但是二级缓存可以让不同的会话共享数据,这可以减少数据库的访问次数。最后,缓存失效的机制也不一样。一级缓存在会话结束时会被清空,而二级缓存可以根据一些设置来失效和更新。

一级缓存适合在一个会话里共享数据,而二级缓存适合多个会话之间的数据共享。但是要记得,二级缓存需要手动设置才能使用哦。根据实际情况,我们可以选择使用不同的缓存级别。

MyBatis中XML映射有哪些标签?

除了常见的select、insert、update和delete标签,MyBatis的XML映射文件中还有一些其他标签用于更复杂的操作和配置。以下是一些常见的额外标签:

1 resultMap: 用于定义查询结果与Java对象之间的映射关系,可以在多个查询中重复使用。
2 association和collection: 用于在resultMap中定义关联关系,用于处理一对一和一对多的关系。
3 discriminator: 在resultMap中使用,根据不同的条件选择不同的映射规则,用于处理继承关系的映射。
4 sql: 可以定义可重用的SQL片段,然后在其他地方引用。主要用于减少重复编写SQL语句。
5 include: 用于在SQL语句中引入外部定义的SQL片段,提高可维护性。
6 if、choose、when、otherwise: 用于在SQL语句中进行条件判断和逻辑控制,用于动态SQL的构建。
7 trim、where、set: 用于在SQL语句中添加固定的SQL片段,如where和set关键字,用于动态的条件构建。
8 foreach: 用于在SQL语句中进行集合迭代,适用于生成IN语句等。
9 bind: 用于在SQL语句中声明并绑定一个变量,可以在查询中重复使用。
10 cache: 用于配置二级缓存。
11 selectKey: 用于在插入操作后获取生成的主键值。
12 insert、update、delete的flushCache、useGeneratedKeys、keyProperty属性: 用于配置插入、更新和删除操作的一些属性。

#{}和${}的区别是什么?

在MyBatis中,#{}和${}都是用于参数替换的标记,用于将参数值插入到SQL语句中。然而,它们在处理参数值的方式上有一些重要的区别。
1 #{}(预编译):
#{}是用于预编译的参数标记。当使用#{}时,MyBatis会将参数值放入一个预编译的PreparedStatement中,并确保参数值被正确地转义和引用,从而防止SQL注入攻击。
#{}适用于大多数情况,尤其是当参数值是从用户输入中获得时,因为它提供了更好的安全性和可靠性。
示例:

XML

1

SELECT * FROM users WHERE id = #{userId}

2 ${}(字符串替换):
${}是用于字符串替换的参数标记。当使用${}时,MyBatis会直接将参数值嵌入到SQL语句中,不会进行预编译或转义。这可能导致潜在的安全问题,如果不正确地处理参数值,可能会导致SQL注入攻击。
${}适用于一些特殊情况,例如在动态表名、列名或函数调用等情况下,但要谨慎使用,确保参数值的安全性。
示例:

XML

1

SELECT * FROM ${tableName} WHERE id = ${userId}

总结区别:
#{}用于预编译,提供参数安全性,适合大多数情况。
${}用于字符串替换,潜在安全风险较高,仅在特定情况下使用,确保参数值安全。
在实际使用中,推荐优先使用#{}来处理参数,以确保数据库操作的安全性和可靠性。只有在确保参数值不会引发安全问题的情况下,才应该考虑使用${}。

Mybatis 分页

MyBatis在数据库查询中执行分页操作时,通常会使用分页插件来处理。分页插件能够根据数据库的不同,生成适当的分页查询语句,并将查询结果进行分页处理。下面我将解释MyBatis如何进行分页以及分页插件的一般原理。
MyBatis的分页原理:
1 数据库方言(Dialect):不同的数据库(如MySQL、Oracle、SQL Server等)在分页查询语法上有所不同。MyBatis并不直接支持所有数据库的分页语法,而是通过数据库方言来处理。数据库方言是一个抽象层,它根据数据库类型生成相应的分页查询语句。
2 参数传递:在查询方法中,你可以传递分页相关的参数,如页码(pageNumber)和每页条数(pageSize)。
3 分页处理:MyBatis会根据数据库方言生成合适的分页查询语句,然后将查询结果返回给调用者。通常,MyBatis会添加类似LIMIT(对于MySQL)或ROWNUM(对于Oracle)等语句来限制返回的结果行数。
分页插件的原理:
分页插件是一种扩展机制,它允许MyBatis在查询过程中,自动应用分页逻辑而不需要手动编写分页查询语句。分页插件的一般原理如下:
1 拦截器(Interceptor):分页插件实际上是MyBatis的一个拦截器,它可以在查询被执行之前或之后进行干预。
2 处理分页逻辑:在查询执行之前,分页插件会检测是否有分页参数传入。如果有分页参数,插件会根据数据库方言生成适当的分页查询语句。
3 修改查询参数:插件会修改查询的SQL语句,添加分页的限制条件。同时,它还会修改参数对象,将分页参数替换为实际的分页偏移量(offset)和每页条数(limit)。
4 执行查询:修改后的查询语句被执行,得到查询结果。
5 封装分页结果:插件会根据查询结果和分页参数,将查询结果进行切割,得到分页后的结果。
分页插件的使用可以大大简化代码,使得在查询中不必关注分页逻辑,只需传递分页参数即可。一些常用的分页插件包括MyBatis-Paginator、PageHelper等,它们都基于上述原理来实现分页功能。不同的插件可能有不同的配置方式和特性,具体的使用方法和配置请参考各个插件的文档。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值