【Mybatis】Mybatis面试题
创始人
2024-06-02 23:07:42
0

Mybatis面试题

  • 1、什么是Mybatis?
  • 2、介绍下Mybatis的工作原理?
  • 3、Mybatis中缓存的理解?
  • 6、#和$的区别?
  • 7、如何解决属性名和字段名不一致的情况?
  • 8、如何获取自动增长的主键?
  • 9、Mybatis中的设计模式?
  • 10、Mybatis映射文件和配置文件的了解?
    • 10.1 Mybatis映射文件中有哪些标签?
    • 10.2 Mybatis核心配置文件中有哪些标签?
  • 11、Mybatis怎么实现分页的?
  • 12、Mybatis中的执行器?
  • 13、Mybatis中的Mapper接口和Mapper映射文件的一致性问题?
  • 14、DefaultSqlSession的线程安全?
    • 14.2 Spring整合Mybatis是如何来解决数据安全问题的?

1、什么是Mybatis?

Mybatis是一个半ORM框架(对象关系映射),专注于SQL语句,不用关心JDBC操作的其他流程,提高了对数据库的开发效率。

Hibemate是全ORM框架、基于JDBC封装的框架


2、介绍下Mybatis的工作原理?

(1)介绍Mybatis的基本情况:ORM

(2)原理:

  • Mybatis框架的初始化操作
  • 处理SQL请求的流程

系统启动的时候会加载解析全局配置文件和对应的映射文件,加载解析的相关信息存储在Configuration对象,Configuration对象会跟SqlSessionFactory对象绑定,当用户请求到来的时候,会从SqlSessionFactory对象中获取SqlSession。

SqlSessionFactory–>SqlSession


3、Mybatis中缓存的理解?

  • 缓存的作用: 降低数据源的访问频率,从而提高数据源的处理能力,提高服务器的响应速度。
  • Mybatis中的缓存设计:
    • Mybatis中的缓存的架构设计
    • Mybatis中的一级缓存和二级缓存

# 4、Mybatis中如何实现缓存的扩展?


# 5、Mybatis和Hibernate的区别?


6、#和$的区别?

  • Mybatis中获取参数值的两种方式:#{}${}
    -#{}(使用较多的一种方式)
    • #{}的本质是占位符赋值;
    • #{} 是预编译处理,在Mybatis处理#{}的时候会替换为"?“,然后调用PrepareStatement的set方法来对”?"进行赋值。
  • ${}
    - ${}的本质是字符串拼接;
    • ${} 是Mybatis处理的时候就会直接替换,会有SQL注入的风险。

7、如何解决属性名和字段名不一致的情况?

  • 方式一:为查询的字段设置别名,和属性名保持一致;
  • 方式二:当字段符合MySQL的要求使用_,而属性符合java的要求使用驼峰。此时可以在mybatis的核心配置文件中设置一个全局配置,可以自动的将下划线映射为驼峰;
  • 方式三:通过resultMap来设置字段和属性的映射关系;

8、如何获取自动增长的主键?

在使用insert标签的时候,设置标签属性useGeneratedKeys=truekeyProperty=“id”,获取到自动增长的主键。

    insert into t_user values (null,#{username},#{password},#{age},#{gender},#{email})

9、Mybatis中的设计模式?

  • 缓存模块:装饰器模式
  • 日志模块:适配器模式
  • SqlSessionFactory:工厂模式
  • Mapper接口:代理模式
  • SqlSessionFactoryBuiler:建造者模式

10、Mybatis映射文件和配置文件的了解?

10.1 Mybatis映射文件中有哪些标签?

  • 处理CRUD操作的标签:
    selectdeleteupdateinsert

  • sql:SQL代码片段

  • cache:开启缓存需要在映射文件中设置cache标签

  • cache-ref:

  • resultMap:自定义映射关系

10.2 Mybatis核心配置文件中有哪些标签?

  • properties:引入properties配置文件,例如配置数据库的jdbc.properties

  • settings:可以设置自动将下划线映射为驼峰、开启延迟加载、按需加载等。

  • typeAliases:类型别名。

  • environments :配置链接数据库的环境

  • mappers:引入MyBatis的映射文件。


11、Mybatis怎么实现分页的?

逻辑分页和物理分页两种

  • 逻辑分页

    • 数据库中有10000条数据,会给服务器10000条数据,客户端需要5条数据去分页,则服务器给客户端5条数据实现分页,这是一种虚拟的分页。
    • 不是真正的分页,RowBounds来进行分页。
  • 物理分页

    • 数据库中有10000条数据,会给服务器10000条数据,客户端需要5条数据去分页,服务器会给客户端10000条数据,然后分页。

    • 我们通过拦截器来实现分页的,

      select * from xxx —> select * from (select * from xxx) t limit 0.10


12、Mybatis中的执行器?

执行器是什么?

SimpleExector:简单的执行器。每次执行操作都会开启一个新的Statement对象,用完就会like关闭。

ReuseExector:复用的执行器。实现了对Statement对象的复用。

BatchExector:可执行批处理任务的执行器。

所有的执行器都必须是在SqlSession的生命周期之内。


13、Mybatis中的Mapper接口和Mapper映射文件的一致性问题?

  • Mapper接口类的名称和Mapper映射文件的名称要保持一致;
  • namespace的名称要和接口类的全类路径要保持一致;
  • Mapper接口类中的方法名要和Mapper映射文件中Sql语句的id属性保持一致;
  • Mapper接口类中方法的返回类型要和Mapper映射文件中SQL语句的返回类型一致;

14、DefaultSqlSession的线程安全?

DefaultSqlSession是线程不安全的。

## 14.1 DefaultSqlSession是什么?

14.2 Spring整合Mybatis是如何来解决数据安全问题的?

我们在工作中都不会单独的使用DefaultSqlSession,而是整合了Spring框架来使用Mybatis。

  • 不安全的原因
    线程不安全的原因是因为多个线程操作同一个对象,而这个对象被定义为了一个成员变量。

  • 解决的方案
    就是把这个成员变量变成一个局部变量,让多个线程不能操作就可以了。

  • Spring整合Mybatis是如何来解决数据安全问题的
    创建了一个SqlSessionTemplate模板对象,定义了数据库操作的相关的方法,本质上是通过代理对象获取了DefaultSqlSession对象来执行的,而且把DefaultSqlSession对象声明在了局部变量当中,从而解决了线程不安全的问题。

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...