欢迎来到培训无忧网!

全国切换

咨询热线 400-001-5729

位置:培训无忧网 > 新闻资讯 > 电脑/IT > java培训 >  Java面试之MyBatis那些常见问题

Java面试之MyBatis那些常见问题

来源:培训无忧网-星星 发布人:星星

2021-11-27 11:41:40|已浏览:326次

      一场Java面试会遇到很多技术问题,例如MyBatis技术。MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。下面,老师结合就业面试给大家大家介绍MyBatis相关问题及答案。

      Java面试之MyBatis那些常见问题

1、Mybatis是如何进行分页的?分页插件的原理是什么?
      答:Mybatis使用RowBounds对象进行分页,它是针对ResultSet结果集执行的内存分页,而非物理分页,可以在SQL内直接书写带有物理分页的参数来完成物理分页功能,也可以使用分页插件来完成物理分页。
      分页插件的基本原理是使用Mybatis提供的插件接口,实现自定义插件,在插件的拦截方法内拦截待执行的SQL,然后重写SQL,根据dialect方言,添加对应的物理分页语句和物理分页参数。
2、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的功能。

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

       答:第一种是使用标签,逐一定义列名和对象属性名之间的映射关系。第二种是使用SQL列的别名功能,将列别名书写为对象属性名,比如T_NAME AS NAME,对象属性名一般是name,小写,但是列名不区分大小写,Mybatis会忽略列名大小写,智能找到与之对应对象属性名,你甚至可以写成T_NAME AS NaMe,Mybatis一样可以正常工作。有了列名与属性名的映射关系后,Mybatis通过反射创建对象,同时使用反射给对象的属性逐一赋值并返回,那些找不到映射关系的属性,是无法完成赋值的。

       本文由培训无忧网千锋教育专属课程顾问整理发布,更多Java培训课程资讯欢迎关注培训无忧网Java培训频道或添加老师微信:1503333605010

      注:尊重原创文章,转载请注明出处和链接 https://www.pxwy.cn/news-id-5197.html 违者必究!部分文章来源于网络由培训无忧网编辑部人员整理发布,内容真实性请自行核实或联系我们,了解更多相关资讯请关注java培训频道查看更多,了解相关专业课程信息您可在线咨询也可免费申请试课。关注官方微信了解更多:150 3333 6050

留下你的信息,课程顾问老师会一对一帮助你规划更适合你的专业课程!
  • 姓名:

  • 手机:

  • 地区:

  • 想学什么:

  • 培训无忧网
免 费 申 请 试 听
提交申请,《培训无忧网》课程顾问老师会一对一帮助你规划更适合你的专业课程!