MyBatis-面试题

1. MyBatis 中 #{}和 ${}的区别是什么?

\#{}是预编译处理,${}是字符替换。

在使用 #{}时,MyBatis 会将 SQL 中的 #{}替换成“?”,配合 PreparedStatement 的 set 方法赋值,这样可以有效的防止 SQL 注入,保证程序的运行安全。

2. MyBatis 有几种分页方式?

分页方式:逻辑分页和物理分页。

逻辑分页: 使用 MyBatis 自带的 RowBounds 进行分页,它是一次性查询很多数据,然后在数据中再进行检索。

物理分页: 自己手写 SQL 分页或使用分页插件 PageHelper,去数据库查询指定条数的分页数据的形式。

3. RowBounds 是一次性查询全部结果吗?为什么?

RowBounds 表面是在“所有”数据中检索数据,其实并非是一次性查询出所有数据,因为 MyBatis 是对 jdbc 的封装,在 jdbc 驱动中有一个 Fetch Size 的配置,它规定了每次最多从数据库查询多少条数据,假如你要查询更多数据,它会在你执行 next()的时候,去查询更多的数据。就好比你去自动取款机取 10000 元,但取款机每次最多能取 2500 元,所以你要取 4 次才能把钱取完。只是对于 jdbc 来说,当你调用 next()的时候会自动帮你完成查询工作。这样做的好处可以有效的防止内存溢出。

4. MyBatis 逻辑分页和物理分页的区别是什么?

  • 逻辑分页是一次性查询很多数据,然后再在结果中检索分页的数据。这样做弊端是需要消耗大量的内存、有内存溢出的风险、对数据库压力较大。
  • 物理分页是从数据库查询指定条数的数据,弥补了一次性全部查出的所有数据的种种缺点,比如需要大量的内存,对数据库查询压力较大等问题。

5. MyBatis 是否支持延迟加载?延迟加载的原理是什么?

MyBatis 支持延迟加载,设置 lazyLoadingEnabled=true 即可。

延迟加载的原理的是调用的时候触发加载,而不是在初始化的时候就加载信息。比如调用 a. getB(). getName(),这个时候发现 a. getB() 的值为 null,此时会单独触发事先保存好的关联 B 对象的 SQL,先查询出来 B,然后再调用 a. setB(b),而这时候再调用 a. getB(). getName() 就有值了,这就是延迟加载的基本原理。

6. 说一下 MyBatis 的一级缓存和二级缓存?

  • 一级缓存:基于 PerpetualCache 的 HashMap 本地缓存,它的声明周期是和 SQLSession 一致的,有多个 SQLSession 或者分布式的环境中数据库操作,可能会出现脏数据。当 Session flush 或 close 之后,该 Session 中的所有 Cache 就将清空,默认一级缓存是开启的。
  • 二级缓存:也是基于 PerpetualCache 的 HashMap 本地缓存,不同在于其存储作用域为 Mapper 级别的,如果多个SQLSession之间需要共享缓存,则需要使用到二级缓存,并且二级缓存可自定义存储源,如 Ehcache。默认不打开二级缓存,要开启二级缓存,使用二级缓存属性类需要实现 Serializable 序列化接口(可用来保存对象的状态)。

开启二级缓存数据查询流程:二级缓存 -> 一级缓存 -> 数据库。

缓存更新机制:当某一个作用域(一级缓存 Session/二级缓存 Mapper)进行了C/U/D 操作后,默认该作用域下所有 select 中的缓存将被 clear。

7. MyBatis 和 hibernate 的区别有哪些?

  • 灵活性:MyBatis 更加灵活,自己可以写 SQL 语句,使用起来比较方便。
  • 可移植性:MyBatis 有很多自己写的 SQL,因为每个数据库的 SQL 可以不相同,所以可移植性比较差。
  • 学习和使用门槛:MyBatis 入门比较简单,使用门槛也更低。
  • 二级缓存:hibernate 拥有更好的二级缓存,它的二级缓存可以自行更换为第三方的二级缓存。
  • 7
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# Spring Boot 集成 MyBatis, 分页插件 PageHelper, 通用 Mapper ## 项目依赖 ```xml <!--mybatis--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.1.1</version> </dependency> <!--mapper--> <dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper-spring-boot-starter</artifactId> <version>1.1.1</version> </dependency> <!--pagehelper--> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.1.1</version> </dependency> ``` ## Spring DevTools 配置 在使用 DevTools 时,通用Mapper经常会出现 class x.x.A cannot be cast to x.x.A。 同一个类如果使用了不同的类加载器,就会产生这样的错误,所以解决方案就是让通用Mapper和实体类使用相同的类加载器即可。 DevTools 默认会对 IDE 中引入的所有项目使用 restart 类加载器,对于引入的 jar 包使用 base 类加载器,因此只要保证通用Mapper的jar包使用 restart 类加载器即可。 在 `src/main/resources` 中创建 META-INF 目录,在此目录下添加 spring-devtools.properties 配置,内容如下: ```properties restart.include.mapper=/mapper-[\\w-\\.]+jar restart.include.pagehelper=/pagehelper-[\\w-\\.]+jar ``` 使用这个配置后,就会使用 restart 类加载加载 include 进去的 jar 包。 ## 集成 MyBatis Generator 通过 Maven 插件集成的,所以运行插件使用下面的命令: >mvn mybatis-generator:generate Mybatis Geneator 详解: >http://blog.csdn.net/isea533/article/details/42102297 ## application.properties 配置 ```properties #mybatis mybatis.type-aliases-package=tk.mybatis.springboot.model mybatis.mapper-locations=classpath:mapper/*.xml #mapper #mappers 多个接口时逗号隔开 mapper.mappers=tk.mybatis.springboot.util.MyMapper mapper.not-empty=false mapper.identity=MYSQL #pagehelper pagehelper.helperDialect=mysql pagehelper.reasonable=true pagehelper.supportMethodsArguments=true pagehelper.params=count=countSql ``` ## application.yml 配置 完整配置可以参考 [src/main/resources/application-old.yml](https://github.com/abel533/MyBatis-Spring-Boot/blob/master/src/main/resources/application-old.yml) ,和 MyBatis 相关的部分配置如下: ```yaml mybatis: type-aliases-package: tk.mybatis.springboot.model mapper-locations: classpath:mapper/*.xml mapper: mappers: - tk.mybatis.springboot.util.MyMapper not-empty: false identity: MYSQL pagehelper: helperDialect: mysql reasonable: true supportMethodsArguments: true params: count=countSql ``` 注意 mapper 配置,因为参数名固定,所以接收参数使用的对象,按照 Spring Boot 配置规则,大写字母都变了带横线的小写字母。针对如 IDENTITY(对应i-d-e-n-t-i-t-y)提供了全小写的 identity 配置,如果 IDE 能自动提示,看自动提示即可。 ## SSM集成的基础项目 >https://github.com/abel533/Mybatis-Spring ## MyBatis工具 http://www.mybatis.tk - 推荐使用 Mybatis 通用 Mapper3 https://github.com/abel533/Mapper - 推荐使用 Mybatis 分页插件 PageHelper https://github.com/pagehelper/Mybatis-PageHelper ## 作者信息 - 作者博客:http://blog.csdn.net/isea533 - 作者邮箱:abel533@gmail.com
以下是一些可能的 Mybatis-plus 面试题: 1. 什么是 Mybatis-plus? Mybatis-plus 是基于 Mybatis 的增强工具,简化了 Mybatis 的开发流程,提供了许多方便的功能,如自动生成代码、注解支持、通用 CRUD 操作等。 2. Mybatis-plus 的优势是什么? Mybatis-plus 有以下优势: - 简化开发流程,提高开发效率。 - 提供了许多方便的功能,如自动生成代码、注解支持、通用 CRUD 操作等。 - 提供了一些实用的插件,如分页插件、性能分析插件等。 - 支持 Lambda 表达式,可以更方便地编写条件查询。 3. Mybatis-plus 的架构是什么样的? Mybatis-plus 的架构包括以下组件: - Entity:实体类,对应数据库中的表。 - Mapper:数据访问层,与数据库交互的接口。 - Service:业务逻辑层,处理业务逻辑。 - Controller:控制层,接收请求并调用 Service 处理请求。 4. Mybatis-plus 的注解有哪些? Mybatis-plus 支持以下注解: - @TableName:指定实体类对应的数据库表名。 - @TableId:指定实体类的主键属性。 - @TableField:指定实体类属性对应的数据库列名。 - @Version:指定实体类的乐观锁属性。 5. Mybatis-plus 如何实现分页查询? Mybatis-plus 提供了一个分页插件,可以方便地实现分页查询。具体实现步骤如下: - 添加分页插件依赖。 - 在 Mybatis 配置文件中配置分页插件。 - 在 Mapper 接口中添加查询方法,并使用 Page 类作为参数。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 Page 对象。 6. Mybatis-plus 如何实现条件查询? Mybatis-plus 支持 Lambda 表达式,可以更方便地编写条件查询。具体实现步骤如下: - 在实体类中定义查询条件属性。 - 在 Mapper 接口中添加查询方法,并使用 LambdaQueryWrapper 类构建查询条件。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 LambdaQueryWrapper 对象。 7. Mybatis-plus 如何实现自动生成代码? Mybatis-plus 提供了一个代码生成器,可以方便地生成 Entity、Mapper、Service 和 Controller 等代码。具体实现步骤如下: - 添加代码生成器依赖。 - 在配置文件中配置代码生成器相关信息。 - 运行代码生成器,生成代码。 8. Mybatis-plus 如何实现多表关联查询? Mybatis-plus 支持多表关联查询,可以使用 JoinWrapper 类进行关联查询。具体实现步骤如下: - 在 Mapper 接口中添加查询方法,并使用 JoinWrapper 类构建关联查询条件。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 JoinWrapper 对象。 9. Mybatis-plus 如何实现乐观锁? Mybatis-plus 支持乐观锁,可以使用 @Version 注解指定乐观锁属性。具体实现步骤如下: - 在实体类中添加 @Version 注解。 - 在 Mapper 接口中添加更新方法,使用 UpdateWrapper 类构建更新条件。 - 在 Service 层中调用 Mapper 接口的更新方法,传入 UpdateWrapper 对象。 10. Mybatis-plus 如何进行性能优化? Mybatis-plus 的性能优化可以从以下方面入手: - 使用缓存,减少数据库访问次数。 - 合理使用分页插件,避免一次查询过多数据。 - 避免使用大量嵌套查询。 - 使用索引优化查询效率。 - 合理使用数据库连接池,避免频繁创建连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值