当前位置: 首页 > news >正文

Mybatis面试

Mybatis 面试

1、Mybatis 的执行流程是什么?

1、读取MyBatis配置文件:mybatis-config.xml 加载运行环境 和 映射文件

2、构造会话工厂 SqlSessionFactory (全局只有一个)

3、会话工厂创建SqlSession对象(项目与数据库的会话,包含了执行SQL 语句的所有方法,每次操作都会创建一个会话)

4、操作数据库接口,Executor 执行器,同时负责查询缓存的维护

5、Executor 接口的执行方法中有一个 MappedStatement 类型的参数,封装了映射信息

6、输入参数映射,将 Java 的对象转化为数据库所支持的类型

7、输出映射结果,再将执行后数据库的类型转化为 Java 类型

2、Mybatis 是否支持延迟加载?

Mybatis 支持延迟加载,但默认没用开启;

(局部的延迟加载)Mybatis 支持 一对一关联对象 和 一对多关联集合对象的延迟加载(加 fetchType=“lazy”)

(全局的延迟加载)可以 在Mybatis 配置文件中,可以配置是否启用延迟加载 lazyLoadingEnabled=true|false

  • 什么是延迟加载?

假设 有一个 User 实体类 ,其里面封装了关于订单的 List 属性,当查询用户时,将订单数据也查出来,此时为立即加载;若查询用户时,暂时不查询订单数据,当只有需要查询List的时候进行查询,此时为延迟加载

  • 延迟加载的原理

1、使用CGLIB 创建目标对象的代理对象

2、当调用目标方法 user.getOrderList() 时,进入拦截器invoke 方法,发现 user.getOrderList() 是 null 值,执行 sql 查询 order表

3、将order查询出来,进行封装返回

3、Mybatis 的一级、二级缓存

本地缓存,基于PerpetualCache,本质是一个HashMap

  • 一级缓存:

基于 PerpetualCache 的 HashMap 本地缓存,其存储作用域为 Session(sqlSession),当Session进行flush或close之该Session中的所有Cache就将清空,默认打开一级缓存。

当两次查询相同时(同一个sqlSession),只会执行一次 SQL ,第一次查询后会将数据放入本地缓存中,第二次查询时,直接从缓存中得到数据。

  • 二级缓存:

作用域是namespace和mapper的作用域,不依赖于session,默认采用 PerpetualCache 的 HashMap 存储,默认时关闭二级缓存的。

开启二级缓存 在Mybatis 配置文件中 开启二级缓存 cacheEnable=true|false,并在映射文件中加 <cache/>标签 ,这时就开启了二级缓存。

当开启二级缓存时,两次查询条件相同时,但调用不同的sqlSession,只会执行一次 SQL 。

注意事项:
1,对于缓存数据更新机制,当某一个作用域(一级缓存 Session/二级缓存Namespaces)的进行了新增、修改、删除操作后,默认该作用域下所有 select 中的缓存将被 clear。

2,二级缓存需要缓存的数据实现Serializable接口。

3,只有会话提交或者关闭以后,一级缓存中的数据才会转移到二级缓存中

4、Mybaits $ 和 # 的区别?

#{ }可以防止Sql 注入,它会将所有传入的参数作为一个字符串来处理。

Mybatis在处理#{}时,会将SQL语句中的#{}替换为?号,调用PrepaerdStatement的set方法来赋值。

$ {} 则将传入的参数拼接到Sql上去执行,一般用于表名和字段名参数,$ 所对应的参数应该由服务器端提供,前端可以用参数进行选择,避免 Sql 注入的风险 。

Mybatis在处理 时,就是把 {}时,就是把 时,就是把{}换成变量的值。

http://www.lryc.cn/news/413778.html

相关文章:

  • Centos 8系统xfs文件系统类型进行扩容缩容 (LVM)
  • C语言基础知识之函数指针和指针函数
  • 【Unity】web gl inputFied 中文输入,同时支持TextMeshInputFied,支持全屏
  • vue3+vite全局引入less变量和函数
  • H81002S 1.7mm网络变压器:BMS汽车蓝牙接收器中的超薄共模电感科技
  • C语言.回调函数
  • 《从零开始:使用Python构建简单Web爬虫》
  • 最新个人免签约支付系统源码|PHP源码 | 码支付系统 | ThinkPHP6框架 | 开源
  • The Llama 3 Herd of Models 第4部分后训练的全文
  • MongoDB性能调优
  • 【Qt开发】调试log日志QDebug重定向输出到textEdit等控件(qInstallMessageHandler回调函数)
  • 【JavaEE精炼宝库】 网络编程套接字——UDP业务逻辑 | TCP流套接字编程及业务逻辑实现
  • 前端过渡动画
  • actual combat 38 ——vue
  • 测试面试宝典(四十七)— 功能测试用例一般包含哪些内容
  • rust_mac环境安装
  • 【前端面试】七、算法-递归
  • CmsEasy逻辑漏洞--零元购
  • Linux 内核源码分析---I/O 体系结构与访问设备
  • 在cPanelWHM中如何重置 MySQL 用户帐户密码
  • 软件测试基础1--功能测试
  • 《计算机网络》(第8版)第9章 无线网络和移动网络 复习笔记
  • 非负数、0和正整数 限制最大值且保留两位小数在elementpuls表单中正则验证
  • Java多线程-----定时器(Timer)及其实现
  • 【Linux修行路】进度条小程序
  • 网络安全入门教程(非常详细)从零基础入门到精通,看完这一篇就够了。
  • 【探索Linux】P.44(数据链路层 —— 以太网的帧格式 | MAC地址 | MTU | ARP协议)
  • <数据集>航拍行人识别数据集<目标检测>
  • 在 Windows 10 系统上部署 Medusa
  • Linux进程 (冯诺依曼体结构 管理 PCB 进程状态 僵尸进程 孤儿进程 运行阻塞挂起状态 进程优先级)