Java面试手册V2.0+突击V3.0知识点整理(二十一) 附封面图片

在这里插入图片描述


1. 什么是Mybatis?
  • Mybatis是一款优秀的支持自定义SQL查询、存储过程和高级映射的持久层框架,消除了几乎所有的JDBC代码和参数的手动设置以及结果集的检索
  • Mybatis可以使用XML或注解进行配置和映射,Mybatis通过将参数映射到配置的SQL形成最终执行的SQL语句,最后将执行的SQL的结果映射成Java对象返回

2. Hibernate优点?
  • Hibernate建立在POJO和数据库表模型的直接映射关系上。通过xml或注解即可和数据库表做映射。通过pojo直接可以操作数据库的数据,它提供的是全表的映射模型
  • 优点:
    • 消除代码映射规则,被分离到xml或注解里配置
    • 无需再管理数据库连接,配置在xml中即可
    • 一个会话中,不要操作多个对象,只要操作Session对象即可
    • 关闭资源只需要关闭Session即可

3. Hibernate缺点?
  • 全表映射带来的不便,比如更新需要发送所有的字段
  • 无法根据不同的条件组装不同的sql
  • 对多表关联和复杂的sql查询支持较差,需要自己写sql,返回后,需要自己将数据组成pojo
  • 不能有效支持存储过程
  • 虽然有hql,但是性能较差,大型互联网需要优化sql,而hibernate做不到

4. Mybatis优点?
  • 小巧,学习成本低
  • 对比JDBC, 基本配置好了配置,大部分的工作量就专注在sql部分
  • 方便维护管理,sql不需要在Java代码中找,sql代码可以分离出来,重用
  • 接近JDBC,灵活,支持动态sql
  • 支持对象与数据库orm字段关系映射

5. Mybatis缺点?
  • 由于工作量在sql上,需要对sql熟练度高
  • 移植性差。sql语法依赖数据库,不同数据库切换会因语法差异而报错

6. 什么时候用Mybatis?
  • 需要一个灵活的、可以动态生成映射关系的框架时。大部分互联网项目使用Mybatis比例是很高的

7. Mybatis核心组件有哪些?分别是?
  • SqlSessionFactoryBuilder(构造器):它会根据配置信息或者代码来生成sqlSessionFactory
  • SqlSessionFactory(工厂接口): 依靠工厂来生成SqlSession
  • SqlSession(会话):既可以发送sql去执行返回结果,也可以获取Mapper接口
  • SQL Mapper:它是新设计的组件,是由一个Java接口和XML文件(或注解)构成的。需要给出对象的SQL和映射规则。它负责发送SQL去执行,并返回结果

8. #{}和${}的区别是什么?
  • ${}是字符串替换,#{}是预编译处理。一般用#{}防止sql注入问题

9. Mybatis中9个动态标签
  • if
  • choose (when、otherwise)
  • trim(where、set)
  • foreach
  • bind

10. xml映射文件中,有哪些标签?
  • select | insert | update | delete | resultMap | parameterMap | sql | include | selectKey 加上9个动态标签(sql为片段标签,通过标签引入sql片段,为不支持自增的主键生成策略标签)

上一篇:Java面试手册V2.0+突击V3.0知识点整理(二十) 附封面图片😍
下一篇:Java面试手册V2.0+突击V3.0知识点整理(二十二) 附封面图片😍


如果觉得封面图片还行,请顺手点个赞😍

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SimpleZihao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值