Mybatis的面试题

1. 什么是一级缓存什么是二级缓存?

MyBatis是一款优秀的持久层框架,它提供了一级缓存和二级缓存来提高数据库访问性能。

一级缓存

一级缓存是指在同一个SqlSession中进行的缓存。当MyBatis执行查询时,查询结果会被缓存在SqlSession的内存中,如果再次执行相同的查询,MyBatis会先检查一级缓存中是否有相同的查询结果,如果有就直接返回缓存的结果,而不再去数据库中执行查询。一级缓存的有效范围是同一个SqlSession,当SqlSession关闭时,一级缓存也会被清空。

二级缓存

二级缓存是指多个SqlSession共享的缓存。当MyBatis执行查询并将结果缓存到二级缓存中时,其他SqlSession也可以从这个二级缓存中获取相同的查询结果。因此,当有多个SqlSession对同一个数据进行操作时,可以通过二级缓存避免多次查询数据库。需要注意的是,二级缓存是跨SqlSession的,但是默认情况下是关闭的,需要手动配置开启。

总的来说,一级缓存是SqlSession级别的缓存,生命周期较短,而二级缓存是多个SqlSession共享的缓存,生命周期较长。使用缓存可以减少数据库的访问次数,提高系统性能,但同时也需要注意缓存的更新策略和缓存带来的数据一致性问题。

2. #{}和${}区别?

  1. #{}语法:

    • #{}语法表示使用预编译的SQL语句,使用占位符将参数值安全地替换到SQL语句中。这种方式可以有效防止SQL注入攻击,并且会自动进行参数类型转换。
    • 例如:SELECT * FROM user WHERE id = #{id}。在执行SQL语句时,#{id}会被实际的参数值替换,类似于预编译语句中的占位符。
  2. ${}语法:

    • ${}语法表示使用文本替换的方式将参数值直接嵌入到SQL语句中,不进行预编译处理。这种方式更加灵活,但也存在一些风险,如SQL注入攻击。
    • 例如:SELECT * FROM user WHERE id = ${id}。在执行SQL语句时,${id}会被实际的参数值直接替换,相当于简单的文本替换。

区别总结:

  • #{}是预编译的占位符语法,更安全,能够防止SQL注入,会自动进行参数类型转换。
  • ${}是文本替换的方式,更灵活,但潜在地存在SQL注入风险,不进行参数类型转换。

因此,为了安全起见,推荐在构建动态SQL时多使用#{}占位符语法,并避免直接使用${}语法。

3.resultMap,resultType的区别,怎么实现的?

在MyBatis中,resultMapresultType都是用于映射查询结果的元素,但它们有一些区别。

  1. resultMap

    • resultMap是用于定义复杂的结果集映射关系的元素。通过resultMap可以指定如何将查询结果映射到对象的属性,可以处理多表联合查询、嵌套查询等复杂的映射情况。
    • 通常情况下,当需要进行复杂的结果映射时,会使用resultMap来定义映射规则,然后在SQL语句中引用这个resultMap
    • resultMap的定义包括了对每个查询字段与对象属性之间的映射关系,可以灵活地处理各种复杂的查询结果映射情况。
  2. resultType

    • resultType是用于简单的结果映射的元素,用于指定查询结果应该被映射到的对象类型。通常用于简单的查询,只需要将结果映射到一个简单的JavaBean对象时使用。
    • 当查询结果只有一张表的字段,且这些字段可以直接映射到一个JavaBean对象的属性时,可以使用resultType来指定结果映射的目标类型。

实现方式:

  • resultMap的实现方式是通过在MyBatis的映射文件中使用<resultMap>元素来定义映射规则,其中可以指定字段到属性的映射关系、嵌套结果映射等。
  • resultType的实现方式是通过在SQL语句的SELECT语句中使用resultType属性来指定结果映射的目标类型,通常是一个简单的JavaBean类型。

总结:

  • resultMap适用于复杂的结果集映射,能够处理多表联合查询、嵌套查询等复杂情况。
  • resultType适用于简单的结果集映射,适用于将查询结果映射到单个JavaBean对象的情况。

在实际使用中,根据查询的复杂度和结果映射的需求,选择使用resultMapresultType来定义查询结果的映射关系。

代码示例:

  1. 使用resultMap进行结果映射:
<!-- 在映射文件中定义resultMap -->
<resultMap id="userResultMap" type="User"><id property="id" column="user_id"/><result property="username" column="username"/><result property="age" column="age"/>
</resultMap><!-- 在SQL语句中引用resultMap -->
<select id="selectUserById" resultMap="userResultMap">SELECT user_id, username, age FROM user WHERE user_id = #{userId}
</select>
  1. 使用resultType进行结果映射:
<!-- 直接在SQL语句中指定resultType -->
<select id="selectUserById" resultType="User">SELECT user_id, username, age FROM user WHERE user_id = #{userId}
</select>

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

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

相关文章

uniapp实现路由拦截——实战案例(二)

uniapp如何实现登录路由拦截&#xff1f; 今天再次介绍一下 uni-simple-router 插件&#xff0c;记得最初使用时&#xff0c;是在三年以前了&#xff0c;这里简单介绍通过自动读取 pages.json 作为路由表的方式&#xff0c;欢迎指教~ 文章目录 uniapp如何实现登录路由拦截&…

LangChain入门学习笔记(二)——LangChain表达式语言(LCEL)

基于LangChain框架编写大模型应用的过程就像垒积木&#xff0c;其中的积木就是Prompts&#xff0c;LLMs和各种OutputParser等。如何将这些积木组织起来&#xff0c;除了使用基本Python语法调用对应类的方法&#xff0c;一种更灵活的方法就是使用位于LangChain-Core层中的LCEL&a…

SwiftUI 6.0(Xcode 16)全新 @Entry 和 @Previewable 宏让开发妙趣横生

概览 如火如荼的 WWDC 2024 已进入第五天&#xff0c;苹果开发平台中众多海量新功能都争先恐后的喷薄欲出。 在这里就让我们从中挑两个轻松有趣的新功能展示给小伙伴们吧&#xff1a;它们分别是 全新的 Entry 和 Previewable 宏。 在本篇博文中&#xff0c;您将学到如下内容&a…

dayjs将星期的第一天设置为周一

默认引入的dayjs的语言是英文&#xff0c;一周的开始是星期日&#xff0c;当使用dayjs().startOf(week)的时候&#xff0c;就不是周一而是周日了。 import dayjs from "dayjs" import "dayjs/locale/zh-cn" import updateLocale from "dayjs/plugin/…

【Python】 探索 CatBoost:高效的机器学习分类与回归工具

我们都找到天使了 说好了 心事不能偷藏着 什么都 一起做 幸福得 没话说 把坏脾气变成了好沟通 我们都找到天使了 约好了 负责对方的快乐 阳光下 的山坡 你素描 的以后 怎么抄袭我脑袋 想的 &#x1f3b5; 薛凯琪《找到天使了》 在机器学习领域中&#xff…

【C++ 11 新特性】lambda 表达式详解

文章目录 1. 常见 lambda 面试题&#x1f58a; 1. 常见 lambda 面试题&#x1f58a; &#x1f34e;① 如果⼀个 lambda 表达式作为参数传递给⼀个函数&#xff0c;那这个函数可以使⽤这个 lambda 表达式捕获的变量吗 ? &#x1f427; 函数本身无法直接访问到 lambda表达式捕获…

vue3实现表格的分页以及确认消息弹窗

表格的分页实例展示 效果1:表格按照每行10条数据分页,且编号也会随之分页自增 实现按照页码分页效果 第二页 展示编号根据分页自动增长 固定表格高度 这边设置了滚动条,同时表格高度实现自适应滚动条高度 template部分 表格代码 编号是按照页码条数进行循环并根据索引自增…

力扣191. 位1的个数

Problem: 191. 位1的个数 文章目录 题目描述思路复杂度Code 题目描述 思路 题目规定数值的范围不会超过32位整形数 1.定义统计个数的变量oneCount&#xff1b;由于每次与给定数字求与的变量mask初始化为1 2.for循环从0~32&#xff0c;每一次拿mask与给定数字求与运算&#xff…

【Linux应用】Linux系统的设备管理——Udev

1.udev概述 udev是 Linux2.6内核里的一个功能&#xff0c;它替代了原来的 devfs&#xff0c;成为当前 Linux 默认的设备管理工具&#xff0c;能够根据系统中的硬件设备的状态动态更新设备文件&#xff0c;包括设备文件的创建&#xff0c;删除等。 udev以守护进程的形式运行&am…

YOLOv10的使用总结

目录 YOLOv10介绍 部署和使用示例 微调训练 YOLO模型因其在计算成本和检测性能之间的平衡而在实时目标检测中很受欢迎。前几天YOLOv10也刚刚发布了。我们这篇文章就来看看YOLOv10有哪些改进&#xff0c;如何部署&#xff0c;以及微调。 概述 实时物体检测旨在以较低的延迟准…

JC/T 2653-2022 不发火砂浆检测

不发火砂浆是指当材料与金属等坚硬物发生摩擦、冲击或冲擦等机械作用时&#xff0c;不产生火花或火星的砂浆。 JC/T 2653-2022 不发火砂浆检测项目&#xff1a; 测试项目 测试方法 外观 JC/T 2653 抗压强度 GB/T 17671 抗折强度 GB/T 17671 保水率 JGJ/T 70 凝结时间…

23.1 时间-获取时间、休眠、超时

1. 获取时间 时间是个重要的编程元素&#xff0c;可用于计算间隔、同步服务器以及控制超时。 计算机中的时间分为以下两种形式&#xff1a; 墙钟时间&#xff1a;以12或24小时为周期不断重复&#xff0c;不同的地区和季节会因时区或夏令时而异。单调时间&#xff1a;从一个时…

CSS 实现电影信息卡片

CSS 实现电影信息卡片 效果展示 CSS 知识点 CSS 综合知识运用 页面整体布局 <div class"card"><div class"poster"><img src"./poster.jpg" /></div><div class"details"><img src"./avtar…

这 10 种架构师,不合格!

大家好&#xff0c;我是君哥。 架构师这个岗位是好多程序员努力的方向&#xff0c;尤其是刚毕业的时候&#xff0c;对架构师有一种崇拜感。毕竟从初级到架构要经历好几次级别飞跃。 工作时间久了&#xff0c;发现架构师这个岗位&#xff0c;其实定义非常广泛&#xff0c;根据工…

工具清单 - 项目管理

# 工具清单 Bonobo Git Server在新窗口打开 - Set up your own self hosted git server on IIS for Windows. Manage users and have full control over your repositories with a nice user friendly graphical interface. (Source Code在新窗口打开) MIT C#Fossil在新窗口打…

windows用脚本编译qt的项目

mingw的 cd build ::设置jom环境 set PATHC:\Qt\Qt5.15.2\Tools\mingw810_32\bin;%PATH% set PATHC:\Qt\Qt5.15.2\5.15.2\mingw81_32\bin;%PATH% ::设置Qt环境 amd64_x86 或者 amd64 ::CALL "D:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Auxilia…

Element-ui中Table表格无法显示

Element-ui中Table表格无法显示 在使用过程中发现样式正常显示但是table就是不显示&#xff0c;研究了一段时间后&#xff0c;发现问题是项目结构的问题 当你创建vue和安装el的时候&#xff0c;一定要注意进入到正确的项目文件夹&#xff0c;如果在外面也出现一个package.jso…

【iOS】UI学习——cell的复用及自定义cell

目录 前言cell的复用手动&#xff08;非注册&#xff09;自动&#xff08;注册&#xff09; 自定义cell总结 前言 Cell复用和自定义Cell是在开发iOS应用时常见的一种优化技巧和定制需求。   Cell复用是UITableView或UICollectionView的一个重要优化机制。当用户滚动这些视图时…

图解 Twitter 架构图

写在前面 两年前&#xff0c;马老板收购了twitter&#xff0c;并且做了一系列的大动作。那么今天我们来看一下这个全球最火的软件之一的架构。 Twitter解析 开始之前&#xff0c;我先提前说明一下&#xff0c;我之前不是做搜推广的&#xff0c;所以对这些了解不是很深&…

实战项目: 负载均衡

0. 前言 这个项目使用了前后端,实现一个丐版的LeetCode刷题网站,并根据每台主机的实际情况,选择对应的主机,负载均衡的调度 0.1 所用技术与开发环境 所用技术: C STL 标准库 Boost 准标准库 ( 字符串切割 ) cpp- httplib 第三方开源网络库 ctemplate 第三方开源前端网…