mybatis热点面试题第五弹

news/2025/3/5 20:57:17/

1. MyBatis与Hibernate的区别

答案

  • MyBatis
    • 不完全是一个ORM框架,需要手动编写SQL语句,灵活性高,适合对数据库操作有高性能要求的场景。
    • 缺点是无法做到数据库无关性,如果需要支持多种数据库,需要编写多套SQL映射文件。
  • Hibernate
    • 是一个完整的ORM框架,对象关系映射能力强,数据库无关性好,适合关系模型复杂且对ORM要求高的场景。
    • 缺点是性能可能不如MyBatis,且对SQL的控制不够灵活。

2. 如何解决MyBatis的N+1查询问题?

答案

  • N+1查询问题:在关联查询中,主查询执行一次,每条结果再触发一次关联查询,导致性能问题。
  • 解决方案
    • 使用联合查询:通过JOIN语句一次性查询所有关联数据。
      <select id="selectArticles" resultMap="ArticleResult">SELECT a.*, u.*FROM article aLEFT JOIN user u ON a.author_id = u.id
      </select>
      
    • 使用嵌套查询:在<resultMap>中配置<collection><association>,并指定select属性。

3. MyBatis的动态SQL支持方式有哪些?

答案

  • XML配置方式:通过<if><choose><when>等标签动态拼接SQL。
  • 注解方式:使用@SelectProvider@InsertProvider等注解,结合SqlSession动态生成SQL。
  • #{}${}的区别
    • #{}:预编译占位符,防止SQL注入。
    • ${}:字符串替换,可能导致SQL注入。

4. MyBatis的缓存机制有哪些?

答案

  • 一级缓存:基于PerpetualCacheHashMap本地缓存,作用域为SqlSession,默认开启。
  • 二级缓存:作用域为MapperNamespace),默认不开启,需要在Mapper文件中配置。
    <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
    
  • 缓存更新机制:当执行C/U/D操作后,一级缓存和二级缓存中的相关数据会被清空。

5. 如何优化MyBatis的性能?

答案

  • SQL优化:优化SQL语句,减少不必要的查询和更新。
  • 缓存机制:合理使用一级缓存和二级缓存,减少数据库访问。
  • 批量操作:使用ExecutorType.BATCH模式,减少事务提交次数。
    java">try (SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH)) {for (User user : users) {userMapper.insert(user);}sqlSession.commit();
    }
    
  • 分页插件:使用PageHelper等分页插件,减少数据加载量。

http://www.ppmy.cn/news/1576904.html

相关文章

C#async异步方法和task.Run异步方法的区别:

async 方法和 Task.Run 方法在 C# 中都与异步编程相关,但它们的用途和实现方式有很大区别。以下是对它们的详细对比: 1. 基本定义和用途 1.1 async 方法 定义:async 是一个修饰符,用于定义异步方法。它允许在方法内部使用 await 关键字。 用途:async 方法通常用于处理 I/…

Axure原型模板与元件库APP交互设计素材(附资料)

为了高效地进行APP和小程序的设计与开发&#xff0c;原型设计工具Axure凭借其强大的功能和灵活性&#xff0c;成为了众多产品经理和设计师的首选。本文将详细介绍Axure原型模板APP常用界面组件元件库、交互设计素材&#xff0c;以及多套涵盖电商、社区服务、娱乐休闲、农业农村…

10.【线性代数】—— 四个基本子空间

十、 四个基本子空间 1. 列空间 C ( A ) C(A) C(A) in R m R^m Rm2. 零空间 N ( A ) N(A) N(A) in R n R^n Rn3. 行空间 C ( A T ) C(A^T) C(AT) in R n R^n Rn4. 左零空间 N ( A T ) N(A^T) N(AT) in R m R^m Rm综述5. 新的向量空间 讨论矩阵 A m ∗ n A_{m*n} Am∗n​…

城电科技 | 城市中的“太阳花” 光伏发电新选择

当艺术与科技相遇&#xff0c;会碰撞出怎样的火花&#xff1f;城电科技推出的光伏太阳花&#xff0c;以其独特的设计与智能化的功能&#xff0c;给出了答案。这款产品不仅具备太阳能发电的实用功能&#xff0c;更是一件充满科技属性的艺术型光伏发电产品&#xff0c;吸引了广泛…

【软考-架构】1.2、指令系统-存储系统-cache

GitHub地址&#xff1a;https://github.com/tyronczt/system_architect ✨资料&文章更新✨ 文章目录 指令系统&#x1f4af;考试真题第一题第二题 指令系统-流水线&#x1f4af;考试真题第一题第二题第三题 存储系统&#x1f4af;考试真题第一题第二题关键解析结论 指令系统…

【三.大模型实战应用篇】【4.智能学员辅导系统:docx转PDF的自动化流程】

去年团队庆功宴上,我司CTO端着酒杯过来:“老王啊,咱们现在文档解析做得挺溜了,但老师们总抱怨下载的作业格式乱码…” 我看了眼手机里凌晨三点收到的崩溃警报,把杯里的可乐一饮而尽——得,新的副本又开了。 一、为什么PDF转换比想象中难十倍? 某次用户调研中,数学教研…

http 状态码秒记速查(附速记口诀)

&#x1f680;♥️♥️♥️开发常见 HTTP 状态码总结&#xff0c;按类别分类&#xff0c;便于快速查阅&#x1f447; 快速记忆口诀&#xff1a; 1xx&#xff1a;临时通知&#xff0c;继续操作2xx&#xff1a;成功搞定&#xff0c;无需担心3xx&#xff1a;资源搬家&#xff0c;…

2.反向传播机制简述——大模型开发深度学习理论基础

在深度学习开发中&#xff0c;反向传播机制是训练神经网络不可或缺的一部分。它让模型能够通过不断调整权重&#xff0c;从而将预测误差最小化。本文将从实际开发角度出发&#xff0c;简要介绍反向传播机制的核心概念、基本流程、在现代网络中的扩展&#xff0c;以及如何利用自…