2024年150道高频Java面试题(七十三)

145. MyBatis 支持哪些类型的 SQL 语句?

MyBatis 是一个优秀的持久层框架,它支持多种类型的 SQL 语句,包括但不限于以下几种:

  1. 查询语句
    • SELECT:用于从数据库表中检索数据。
    • SELECTIVE:根据条件选择性地查询数据。
  2. 插入语句
    • INSERT:将新记录插入到数据库表中。
  3. 更新语句
    • UPDATE:更新数据库表中的记录。
  4. 删除语句
    • DELETE:从数据库表中删除记录。

除了基本的 CRUD(创建、读取、更新、删除)操作外,MyBatis 还支持以下类型的 SQL 语句:

  1. 动态 SQL
    MyBatis 使用 OGNL 表达式或 ${} 插入来支持动态 SQL。
    • IF:条件判断。
    • CHOOSE, WHEN, OTHERWISE:类似于 Java 中的 switch 语句。
    • WHERE:简化 SQL 条件的拼接。
    • SET:用于动态更新语句。
    • FOREACH:遍历集合,生成批量操作。
  2. 批量操作
    • 支持通过 <foreach> 标签进行批量插入、更新和删除。
  3. 调用存储过程
    • MyBatis 支持调用数据库存储过程。

以下是一个 MyBatis 动态 SQL 的简单示例:

<mapper namespace="com.example.mapper.UserMapper"><!-- 查询示例 --><select id="selectUser" parameterType="int" resultType="User">SELECT * FROM users WHERE id = #{id}</select><!-- 动态插入示例 --><insert id="insertUser" parameterType="User">INSERT INTO users<trim prefix="(" suffix=")" suffixOverrides=","><if test="name != null">name,</if><if test="email != null">email,</if></trim><trim prefix="VALUES (" suffix=")" suffixOverrides=","><if test="name != null">#{name},</if><if test="email != null">#{email},</if></trim></insert>
</mapper>

以上示例展示了 MyBatis 对各种 SQL 语句的支持,包括静态 SQL 语句和动态 SQL 语句。MyBatis 还支持复杂的映射语句,从而使得 Java 代码与 SQL 语句之间的交互更加灵活和便捷。

146. 什么是 MyBatis 的一级缓存和二级缓存?

MyBatis 的一级缓存和二级缓存是MyBatis提供的两种不同级别的缓存机制,用于减少数据库查询次数,提高应用性能。

一级缓存

一级缓存是默认开启的,它是基于SqlSession级别的缓存。在同一个SqlSession中,执行相同的SQL查询时,MyBatis会首先检查缓存中是否已经存在相应的查询结果。如果存在,则直接从缓存中取出结果,不再执行数据库查询。

  • 特点:

    • 同一个SqlSession内有效。
    • 不需要配置,自动支持。
    • 缓存的生命周期与SqlSession相同。
  • 代码示例:

    SqlSession sqlSession = sqlSessionFactory.openSession();
    try {UserMapper userMapper = sqlSession.getMapper(UserMapper.class);User user1 = userMapper.getUserById(1); // 查询数据库User user2 = userMapper.getUserById(1); // 从一级缓存中获取,不会查询数据库
    } finally {sqlSession.close();
    }
    

二级缓存

二级缓存是基于namespace级别的缓存,可以被多个SqlSession共享,通常是基于同一个Mapper接口或者同一个XML Mapper文件。这意味着在多个SqlSession中执行同一个Mapper中的查询操作时,可以从二级缓存中获取数据。

  • 特点:

    • 多个SqlSession之间共享。
    • 需要在Mapper配置文件中显式地开启 <cache> 标签。
    • 缓存的生命周期和应用相同,或者直到清理缓存为止。
    • 可以通过 eviction、flushInterval、size 等属性进行配置。
  • 代码示例(在Mapper XML文件中开启二级缓存):

    <mapper namespace="com.example.mapper.UserMapper"><cache eviction="FIFO" flushInterval="60000" size="512" /><!-- Mapper 的 SQL 语句 -->
    </mapper>
    

二级缓存使用时需要注意的是,如果涉及到数据的更新操作,为了保证缓存的一致性,MyBatis会默认清除对应Mapper下的二级缓存。此外,也可以通过自定义缓存实现来进一步控制缓存的行为。

综上,一级缓存主要用于SqlSession内部,而二级缓存则适用于跨多个SqlSession的场景,两者都可以有效地减少数据库访问次数,提高应用的数据处理效率。

编程资料包领取:https://pan.quark.cn/s/601cbea644ff
编程、AI、副业交流:https://t.zsxq.com/19zcqaJ2b
领【150 道精选 Java 高频面试题】请 go 公众号:码路向前 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/16677.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

请说出vue.cli项目中src目录每个文件夹和文件的用法

在Vue CLI项目中&#xff0c;src目录是存放项目源码及需要引用的资源文件的主要位置。以下是src目录下常见文件夹和文件的用法&#xff1a; components 用途&#xff1a;存放可重用的Vue组件。这些组件通常用于在多个页面或布局中共享UI和功能。特点&#xff1a;组件应该是模块…

Midjourney 推出Style Tuner工具 ,统一风格,提升创作效率!

Midjourney 由前 Magic Leap 程序员大卫 - 霍尔茨&#xff08;David Holz&#xff09;构思&#xff0c;于 2022 年夏天推出&#xff0c;在独立消息应用 Discord 的服务器上吸引了超过 1600 万用户&#xff0c;并由一个小规模的程序员团队不断更新&#xff0c;推出了包括平移、扩…

【openlayers系统学习】00官网的Workshop介绍

00Workshop介绍 官方文档&#xff1a;https://openlayers.org/workshop/en/ openlayers官网Workshop学习。 通过官网Workshop&#xff0c;系统学习openlayers的使用。 基本设置 这些说明假定您从最新Workshop版本的 openlayers-workshop-en.zip​ 文件开始。此外&#xff…

并行模拟退火算法的golang练手实现

模拟退火&#xff08;Simulated Annealing, SA&#xff09;算法是一种概率型启发式搜索算法&#xff0c;它模仿了物理世界中的退火过程。退火是一种金属加工技术&#xff0c;通过缓慢降低材料的温度来减少其内部的缺陷。在优化问题中&#xff0c;模拟退火算法用于寻找全局最优解…

AI大模型探索之路-实战篇8:多轮对话与Function Calling技术应用

系列篇章&#x1f4a5; AI大模型探索之路-实战篇4&#xff1a;深入DB-GPT数据应用开发框架调研 AI大模型探索之路-实战篇5&#xff1a;探索Open Interpreter开放代码解释器调研 AI大模型探索之路-实战篇6&#xff1a;掌握Function Calling的详细流程 AI大模型探索之路-实战篇7…

Nginx SSL/TLS配置:搭建安全的HTTPS网站

随着互联网安全性的日益提升&#xff0c;HTTPS已经成为网站安全通信的标配。Nginx作为一款高性能的HTTP和反向代理服务器&#xff0c;支持SSL/TLS协议&#xff0c;使得我们可以轻松地搭建安全的HTTPS网站。下面&#xff0c;我们将详细介绍如何在Nginx上配置SSL/TLS&#xff0c;…

实验五:实现循环双链表各种基本运算的算法

实验五&#xff1a;实现循环双链表各种基本运算的算法 一、实验目的与要求 目的:领会循环双链表存储结构和掌握循环双链表中各种基本运算算法设计。 内容:编写一个程序cdinklist.cpp,实现循环双链表的各种基本运算和整体建表算法(假设循环双链表的元素类型ElemType为char),并…

俄罗斯半导体领域迈出坚实步伐:首台光刻机诞生,目标直指7纳米工艺

近日&#xff0c;国外媒体纷纷报道&#xff0c;俄罗斯在半导体技术领域取得了重要突破&#xff0c;首台光刻机已经制造完成并正在进行严格的测试阶段。这一里程碑式的事件标志着俄罗斯在自主发展半导体技术的道路上迈出了坚实的一步。 据俄罗斯联邦工业和贸易部副部长瓦西里-什…

基于光纤传感器的平面曲线重建算法建模

**基于光纤传感器的平面曲线重建算法建模** 一、引言 随着科技的快速发展&#xff0c;光纤传感技术作为一种新型传感器技术&#xff0c;已经广泛应用于各个领域。其中&#xff0c;基于光纤传感器的平面曲线重建算法建模是一个重要的研究方向。本文旨在探讨如何利用光纤传感器…

【源码】2024心悦搜剧源码百万级网盘资源

1、一键转存他人链接&#xff1a;就是将别人的分享链接转为你自己的 2、转存心悦搜剧资源&#xff1a;就是将心悦搜剧平台上的所有资源都转成你自己的 3、每日自动更新&#xff1a;自动转存每天的资源并入库 前端uin-app&#xff0c;后端PHP&#xff0c;兼容微信小程序

【VTKExamples::Utilities】第一期 动画模拟Animation

很高兴在雪易的CSDN遇见你 VTK技术爱好者 QQ:870202403 公众号:VTK忠粉 前言 本文分享VTK样例Animation,希望对各位小伙伴有所帮助! 感谢各位小伙伴的点赞+关注,小易会继续努力分享,一起进步! 你的点赞就是我的动力(^U^)ノ~YO 1. Animation 该样例介绍如…

【设计模式深度剖析】【4】【结构型】【组合模式】| 以文件系统为例加深理解

&#x1f448;️上一篇:适配器模式 设计模式深度剖析-专栏&#x1f448;️ 目 录 组合模式定义英文原话直译如何理解&#xff1f; 3个角色UML类图代码示例 组合模式的优点组合模式的使用场景示例解析&#xff1a;文件系统 组合模式 组合模式&#xff08;Composite Pattern&a…

多段图最短路径(动态规划法)

目录 前言 一、多段图的分析 二、算法思路 三、代码如下&#xff1a; 总结 前言 问题描述&#xff1a;设图G(V, E)是一个带权有向图&#xff0c;如果把顶点集合V划分成k个互不相交的子集Vi (2≤k≤n, 1≤i≤k)&#xff0c;使得对于E中的任何一条边(u, v)&#xff0c;必有u∈Vi&…

MSI U盘重装系统

MSI U盘重装系统 1. 准备一块U盘 首先需要将U盘格式化&#xff0c;这个格式化并不是在文件管理中将U盘里面的所有东西都删干净就可以了&#xff0c;需要在磁盘管理中&#xff0c;将这块U盘格式化&#xff0c;如果这块U盘有分区的话&#xff0c;那将所有的分区都格式化并且删除…

说说你了解过、使用过什么编程语言?比较小他们的优势说说你了解过、使用过什么编程工具?

我了解并且使用过多种编程语言&#xff0c;包括&#xff1a; 1. Python&#xff1a;Python是一种简洁而强大的编程语言&#xff0c;它具有易读性和易学性的特点。它支持面向对象编程和函数式编程&#xff0c;拥有丰富的第三方库和工具&#xff0c;适用于多种应用场景&#xff0…

一个专为程序员设计的精致 Java 博客系统

大家好&#xff0c;我是 Java陈序员。 今天&#xff0c;给大家介绍一个设计精致的博客系统&#xff0c;基于 Java 实现&#xff01; 关注微信公众号&#xff1a;【Java陈序员】&#xff0c;获取开源项目分享、AI副业分享、超200本经典计算机电子书籍等。 项目介绍 bolo-solo …

List过滤重复数据

一、背景&#xff08;着急的同学直接看实现&#xff09; 产品部门向小王提出了一项需求&#xff0c;要求根据多变的条件灵活组合&#xff0c;从一个对象集合中筛选出符合条件的项目。小王初时考虑通过创建多个定制化的equals方法来逐一对比筛选&#xff0c;正当他准备埋头编码…

「架构」SOA(面向服务的架构)

SOA(面向服务的架构)是一种设计模式,用于构建灵活、可互操作和可重用的企业IT系统。SOA基于服务的概念,服务是自包含的、模块化的软件组件,可以被不同的应用程序或业务流程调用。 核心功能: 服务识别与定义:识别业务功能并将其定义为独立的服务。服务抽象:隐藏服务内部…

【面试题】Oracle高频面试题目

简述Oracle中左连接与右连接 &#xff1f; 在Oracle数据库中&#xff0c;左连接&#xff08;left join&#xff09;和右连接&#xff08;right join&#xff09;是两种数据表的连接方式。 左连接是根据左侧表中的所有记录和右侧表中满足连接条件的记录进行匹配&#xff0c;结…