1. #{}和${}的区别

    • #{}是预编译处理,${}是字符串替换。

    • Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

    • Mybatis在处理${}时,就是把${}替换成变量的值。使用#{}可以有效的防止SQL注入,提高系统安全性。

  2. 当实体类中的属性名和表中的字段名不一样,如果将查询的结果封装到指定pojo

    • 通过在查询的sql语句中定义字段名的别名

    • 通过<resultMap>来映射字段名和实体类属性名的一一对应的关系.

  3. 模糊查询like语句该怎么写

    • 在java中拼接通配符,通过#{}赋值

    • 在Sql语句中拼接通配符 (不安全 会引起Sql注入)

  4. 通常一个Xml映射文件,都会写一个Dao接口与之对应, Dao的工作原理,是否可以重载

    • 不能重载,因为通过Dao寻找Xml对应的sql的时候全限名+方法名的保存和寻找策略。

    • 接口工作原理为jdk动态代理原理,运行时会为dao生成proxy,代理对象会拦截接口方法,去执行对应的sql返回数据

  5. Mybatis是如何进行分页的,分页插件实现的原理

    • Mybatis使用RowBounds对象进行分页,也可以直接编写sql实现分页,也可以使用Mybatis的分页插件

    • 分页插件的原理:实现Mybatis提供的接口,实现自定义插件,在插件的拦截方法内拦截待执行的sql,然后重写sql。

  6. Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签

    • <resultMap>、<parameterMap>、<sql>、<include>、<selectKey>加上动态sql的标签,比如where|set|foreach|if|choose|when|otherwise

    • <sql>为sql片段,<include>引入sql片段

  7. Mybatis动态sql是做什么的?都有哪些动态sql?简述一下动态sql的执行原理

    • Mybatis动态sql可以让我们在Xml映射文件内,以标签的形式编写动态sql,完成逻辑判断和动态拼接sql的功能,Mybatis提供了9种动态sql标签trim|where|set|foreach|if|choose|when|otherwise|bind。

    • 使用OGNL从sql参数对象中计算表达式的值,根据表达式的值动态拼接sql,以此来完成动态sql的功能。

  8. Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式

    • 第一种是使用标签,逐一定义列名和对象属性名之间的映射关系。第二种是使用sql列的别名功能,将列别名书写为对象属性名

    • 有了列名与属性名的映射关系后,Mybatis通过反射创建对象,同时使用反射给对象的属性逐一赋值并返回,那些找不到映射关系的属性,是无法完成赋值的。

  9. Mybatis能执行一对一、一对多的关联查询吗?都有哪些实现方式,以及它们之间的区别

    • Mybatis不仅可以执行一对一、一对多的关联查询,还可以执行多对一,多对多的关联查询,多对一查询,其实就是一对一查询,只需要把selectOne()修改为selectList()即可;多对多查询,其实就是一对多查询,只需要把selectOne()修改为selectList()即可。

    • 一种是单独发送一个sql去查询关联对象,赋给主对象,然后返回主对象。另一种是使用嵌套查询,嵌套查询的含义为使用join查询,一部分列是A对象的属性值,另外一部分列是关联对象B的属性值,好处是只发一个sql查询,就可以把主对象和其关联对象查出来。其去重复的原理是标签内的子标签,指定了唯一确定一条记录的id列,

  10. Mybatis是否支持延迟加载

    • Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false。
  11. Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复

    • 不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复;毕竟namespace不是必须的,只是最佳实践而已。原因就是namespace+id是作为Map<String, MappedStatement>的key使用的,如果没有namespace,就剩下id,那么,id重复会导致数据互相覆盖。有了namespace,自然id就可以重复,namespace不同,namespace+id自然也就不同。
  12. 如何进行批处理

    • 使用BatchExecutor完成批处理。
  13. Mybatis都有哪些Executor执行器?它们之间的区别是什么

    • Mybatis有三种基本的Executor执行器,SimpleExecutor、ReuseExecutor、BatchExecutor。

    • SimpleExecutor:每执行一次update或select,就开启一个Statement对象,用完立刻关闭Statement对象。

    • ReuseExecutor:执行update或select,以sql作为key查找Statement对象,存在就使用,不存在就创建,用完后,不关闭Statement对象,而是放置于Map<String, Statement>内,供下一次使用。简言之,就是重复使用Statement对象。

    • 批处理

  14. Mybatis中如何指定使用哪一种Executor执行器

    • 在Mybatis配置文件中,可以指定默认的ExecutorType执行器类型,也可以手动给DefaultSqlSessionFactory的创建SqlSession的方法传递ExecutorType类型参数。
  15. Mybatis映射文件中,如果A标签通过include引用了B标签的内容,位置问题

    • 被引用的B标签依然可以定义在任何地方,Mybatis都可以正确识别。在访问A标签时会标记B标签,然后等全部标签解析完毕会再一次重新解析标记的标签
  16. 为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里

    • Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。
  17. 如何获取自动生成的(主)键值

    • 配置文件设置usegeneratedkeys 为true
  18. 在mapper中如何传递多个参数

    • 直接在方法中传递参数,xml文件用#{0} #{1}来获取

    • 使用 @param 注解:这样可以直接在xml文件中通过#{name}来获取

  19. Mybatis对象关联实例

    • 在单表查询中,属性名和数据库相同的字段可以省略,多表不可省略,省略则为空

      // 一对一
      <resultMap type="Orders" id="orders">
      <result column="id" property="id"/> <association property="user" javaType="User">
      //关联另一张表
      <id column="id" property="id"/> // id
      <result column="name" property="name"></result> // 属性 即查询出来显示的名字
      </association>
      </resultMap> <select id="onemany" resultMap="orders">
      select u.id ,o.number,o.dic,u.name from orders o left JOIN user u on o.user_id=u.id
      </select>
      // 一对多
      <resultMap type="User" id="user">
      <id column="id" property="id"/>
      <result column="name" property="name"/>
      <!-- 一对多 -->
      <collection property="list2" ofType="Orders"> // ofType : 每个属性的类型
      <id column="oid" property="id"/> //需要设置id,如果两个对象属性相同,则会视为一条记录
      <result column="number" property="number"/>
      </collection>
      </resultMap>
      <select id="selectUserList" resultMap="user">
      select u.id,o.id as oid,o.number,o.dic,u.name from user u left JOIN orders o on o.user_id=u.id
      </select>
  20. resultType resultMap的区别

    • 类的名字和数据库相同时,可以直接设置resultType参数为Pojo类

    • 若不同,需要设置resultMap 将结果名字和Pojo名字进行转换,

  21. Map 直接#{key}就可以取得对应的值

Mybatis面试整理的更多相关文章

  1. 就目前市面上的面试整理来说,最全的BAT大厂面试题整理在这

    原标题:就目前市面上的面试整理来说,最全的BAT大厂面试题整理在这 又到了面试求职高峰期,最近有很多网友都在求大厂面试题.正好我之前电脑里面有这方面的整理,于是就发上来分享给大家. 这些题目是网友去百 ...

  2. MyBatis 面试复习整理

    MyBatis MyBatis 是一款优秀的ORM(对象关系映射)框架,可以通过对象和数据库之间的映射,将程序中的对象自动存储到数据库中.它内部封装了 JDBC ,使开发者只需要关注 SQL语句本身, ...

  3. java面试整理

    IO和NIO的区别 这是一个很常见的问题,如果单纯的只回答IO和NIO的区别,只能算及格.我个人觉得应该从以下几个方面回答: 1).IO简介, 2).TCP的三次握手,因为这也是两者的区别之一, 3) ...

  4. 面试整理之DOM事件阶段

    因为快面试了,打开<JavaScript高级程序设计>,对DOM事件进行整理了下 本文主要解决的问题: 事件流 DOM事件流的三个阶段 先理解流的概念 在现今的JavaScript中随处可 ...

  5. MYBATIS 简单整理与回顾

    这两天简单整理了一下MyBatis 相关api和jar包这里提供一个下载地址,免得找了 链接:http://pan.baidu.com/s/1jIl1KaE 密码:d2yl A.简单搭建跑项目 2.进 ...

  6. Mybatis面试集合(转)

    Mybatis技术内幕系列博客,从原理和源码角度,介绍了其内部实现细节,无论是写的好与不好,我确实是用心写了,由于并不是介绍如何使用Mybatis的文章,所以,一些参数使用细节略掉了,我们的目标是介绍 ...

  7. java面试整理(会持续更新..)

    本人出道至今,经历了大大小小百余场战斗,,,下面整理的面试题有些有答案,有些没答案,那个谁说过:"要抱着怀疑的态度去编程,所以,即便有答案,也不一定正确,即便我本地正确,但是由于屏幕前的你和 ...

  8. 面试整理(1):原生ajax

    接到电话面试,有一些送分题答的不好,在这里整理一下 问题:原生ajax的工作流程是怎么样的? 老用封装好的工具,原生的ajax其实并不熟悉,今天复习一下.主要参考http://www.w3school ...

  9. mybatis 一点整理

    mapper指定对应的接口 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper ...

随机推荐

  1. Node.js之循环依赖

    在Node.js中有可能会出现循环依赖的问题,在此做一个简单的记录 假如有一个模块A: exports.loaded = false; const b = require('./b'); module ...

  2. VirtualBox 磁盘容量调整

    起因 此前用VBox,初始时动态或固定分配的磁盘容量用完了就再重新建一个磁盘,但是有个虚拟机的系统分区容量不够了,把整个磁盘都分成系统盘仍然不够,于是研究了下磁盘容量调整问题. 正文 1,从当前虚拟机 ...

  3. 将网页封装成苹果APP的牛逼方法,无需发布到appstore,无需越狱即可安装

    很多小伙伴都在开发自己的app, 有的实现实现比较简单,就是一个h5页面,然后想要打包成app发布出去. 这个想法很单纯 打包生成个app这个是很简单的,网上一堆打包工具,分分钟可以完成 但是... ...

  4. Jquery地图热点效果-鼠标经过弹出提示信息

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  5. RobotFramework自动化测试框架-移动手机自动化测试Click Element At Coordinates关键字的使用

    Click Element At Coordinates关键字通过一个具体的坐标点,来模拟点击一个Element,该关键字接收两个参数[ coordinate_X | coordinate_Y ]. ...

  6. 云计算---openstack各服务端口使用情况

    端口占用情况 端口情况可以使用ss -tanp命令进行查看 监听的所有端口ss -tanp | grep LISTEN 基础服务 22 --SSH 3306 --MariaDB(MySQL) 2701 ...

  7. java之基础数据类型学习————(一)

    JAVA数据类型: 总结来说,java的基本数据类型分为 四类八种 • 第一类:整数类型:byte.short.int.long • 第二类:浮点型:float.double • 第三类:字符类型:c ...

  8. UWP 手绘视频创作工具技术分享系列 - 位图的绘制

    前面我们针对 SVG 的解析和绘制做了介绍,SVG 是图片的一种形式,而另一种很重要的图片是:位图,包括 png.jpeg.bmp 等格式.位图的基本规则是,组成的基本元素是像素点,由宽度 * 高度个 ...

  9. iOS将自己的框架更新到cocopods上

    第一步 把自己的框架更新到github 上,为了提交地址给他人下载.这里就不详细介绍如何把项目更新到github上了 第二步 这个时候我们的项目已经挂在github上了我们需要给本地的项目新建一个Po ...

  10. 我的第一个python web开发框架(8)——项目结构与RESTful接口风格说明

    PS:再次说明一下,原本不想写的太啰嗦的,可之前那个系列发布后发现,好多朋友都想马上拿到代码立即能上手开发自己的项目,对代码结构.基础常识.分类目录与文件功能结构.常用函数......等等什么都不懂, ...