【mybatis】mybatis面试题

【mybatis】mybatis面试题mybatis的基本工作流程1.读取配置文件,配置文件包含数据库连接信息和Mapper映射文件或者Mapper包路径。2.有了这些信息就能创建SqlSessionFactory,SqlSessionFactory的生命周期是程序级,程序运行的时候建立起来,程序结束的时候消亡3.SqlSessionFactory建立SqlSession,目的执行sql语句,SqlSession是过程级,…

大家好,又见面了,我是你们的朋友全栈君。

mybatis的基本工作流程

1.读取配置文件,配置文件包含数据库连接信息和Mapper映射文件或者Mapper包路径。

2.有了这些信息就能创建SqlSessionFactory,SqlSessionFactory的生命周期是程序级,程序运行的时候建立起来,程序结束的时候消亡

3.SqlSessionFactory建立SqlSession,目的执行sql语句,SqlSession是过程级,一个方法中建立,方法结束应该关闭

4.当用户使用mapper.xml文件中配置的的方法时,mybatis首先会解析sql动态标签为对应数据库sql语句的形式,并将其封装进MapperStatement对象,然后通过executor将sql注入数据库执行,并返回结果。

5.将返回的结果通过映射,包装成java对象。

什么是MyBatis的接口绑定,有什么好处  

接口映射就是在IBatis中任意定义接口,然后把接口里面的方法和SQL语句绑定,我们通过直接调用接口方法 例如:

UserMapper  userMapper=sqlSession.getMapper  (UserMapper.class) 就可以,这样比起原来了SqlSession提供的方法,例如List<Country> countryList = sqlSession.selectList(“selectAll”);我们可以有更加灵活的选择和设置.。

注意:(1)Mapper .xml文件的namespace属性必须配置为接口的全限定名称,接口方法名与Mapper.xml中的<select><insert>id值必须相同,且接口方法的返回值类型必须与Mapper.xml配置的resultType一致,这里后者起到决定作用。

(2)select查询通过在Mapper.xml中配置ResultMap标签,将查询结果的列名与字段名对应。

insert语句通过#{属性名}从接口参数获取值放到sql语句中。

(3)Mapper.xml接口绑定本质是动态代理。

接口绑定有几种实现方式,分别是怎么实现的?        

接口绑定有两种实现方式,

(1)注解绑定:就是在接口的方法上面@Select@Update等注解里面包含Sql语句来绑定

(2)另外一种就是通过xml里面写SQL来绑定,在这种情况下,要指定xml映射文件里面的namespace必须为接口的全路径名.

什么情况下用注解绑定,什么情况下用xml绑定        

当Sql语句比较简单时候,用注解绑定,
当SQL语句比较复杂时候,用xml绑定,一般用xml绑定的比较多

MyBatis实现一对一有几种方式?具体怎么操作的

有联合查询和嵌套查询

(1)联合查询是几个表联合查询,只查询一次,

查询结果有三种处理方式:第一种自动映射返回结果为resultType、

第二种配置resultMap,返回结果配置为存在的resultMap,这个resultMap中的Property都要加一个role.Property,表示用户对象中的role对象的property,每一个属性都要加role.很繁琐,association标签就是解决这个问题的。

第三种通过在resultMap里面配置association节点配置一对一的类就可以完成;

【mybatis】mybatis面试题

注意:mybaits支持resultMap映射继承。<ResultMap id=”userRoleMap” extends=”userMap”>
(2)嵌套查询是先查一个表,根据这个表里面的结果的外键id,去再另外一个表里面查询数据,也是通过association配置,但另外一个表的查询通过select属性配置 

【mybatis】mybatis面试题

MyBatis实现一对多有几种方式,怎么操作的

有联合查询和嵌套查询

(1)联合查询是几个表联合查询,只查询一次,通过在resultMap里面配置collection标签配置一对多的类就可以完成;
(2)嵌套查询是先查一个表,根据这个表里面结果的外键id,去再另外一个表里面查询数据,也是通过配置collection,但另外一个表查询通过select节点配置

MyBatis里面的动态Sql是怎么设定的?用什么语法?

MyBatis里面的动态Sql一般是通过if节点来实现,通过OGNL语法来判断,但是如果要写的完整,必须配合where,trim节点,

choose标签 choose when otherwise标签,一个choose中至少有一个when,0或1个otherwise,如果when满足就执行,全不满足就执行otherwise。

【mybatis】mybatis面试题

注意where1=1必须添加,防止where关键字后面没有语句.

where标签是判断包含节点有内容就插入where,如果where后面的字符串是以AND和OR开头的,就将AND和OR提出

【mybatis】mybatis面试题

当if条件都不满足,where元素中没有内容,也就不会出现choose标签那种错误。

set标签更新的时候用:如果该标签包含的元素中有返回值,就插入一个set;如果set后面的字符串是以逗号结尾的,就将这个逗号剔除。

【mybatis】mybatis面试题

注意set标签用法中,SQL后面的逗号没有问题了,但是如果set元素中没有内容,照样会出现SQL错误,所以为了避免错误产生,类似id=#{id}这样必然存在的赋值仍然有保留的必要。

讲下MyBatis的缓存

MyBatis的缓存分为一级缓存和二级缓存,
一级缓存放在session里面,默认就有,二级缓存放在它的命名空间里,默认是打开的,
使用二级缓存属性类需要实现Serializable序列化接口(可用来保存对象的状态),可在它的映射文件中配置<cache/>
 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/140655.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SQL Sever——无法连接到(local)。“未配置远程连接”和“请求失败或服务未及时响应”「建议收藏」

    SQL Sever——无法连接到(local)。“未配置远程连接”和“请求失败或服务未及时响应”

    2022年2月4日
    47
  • 模仿学习对比强化学习「建议收藏」

    模仿学习对比强化学习「建议收藏」模仿学习介绍模仿学习是将专家经验作为样本进行强监督学习的一种方法。模仿学习对比强化学系模仿学习优点:1.简单、稳定的监督学习过程缺点:1.需要提供榜样行为数据2.需要处理多解型行为(例如绕过障碍物,可以从左边或者右边,但是专家数据不一定覆盖所有行为,可以用多元高斯分布去等方法去处理)3.不能超越人类水平强化学习优点:1.可以超越人类水平缺点:1.需要设置奖励函数2.必须解决策略探索性问题3.训练可能不收敛、不稳定结合模仿学习和强化学习:Pretrain&Finetune

    2022年9月18日
    2
  • 怪诞行为学丹 . 艾瑞里_怪诞心理学epub

    怪诞行为学丹 . 艾瑞里_怪诞心理学epub郑重声明:本号收录的电子书均来源于互联网或网友分享,链接内容仅作分享交流学习使用,不用于任何商业用途,版权归原作者和出版社所有,如果喜欢,请支持和购买正版,谢谢。下载地址:http://pan.63

    2022年8月3日
    5
  • 游戏建模:手绘暗黑小萝莉「建议收藏」

    平时喜欢画画,最近呐再做一些个人作品。然后再A站各种淘原画,从一堆原画中挑选自己喜欢的,把它画成模型。然后发现选的原画每次都给自己挖了很多的坑。在选这张原画的时候想的是,小萝莉卡哇伊。一身金闪闪发光blingbling的,贼漂酿。头发直接就是一个条一个条的,全身除了头上的装饰还有肩部的就没啥了,还是ok的。但是在实际的模型制作还有贴图制作中发现,emmmm,有一个深坑,快爬不出来了。谁来救一下可爱的小哥哥。下面呐就是我选的卡哇伊小姐姐。挑战一下这种非正常肤色。(图1原画)下面呐…

    2022年4月11日
    48
  • iframe属性设置

    &lt;iframe runat="server" src="youpage’surl"width="750"height="30"frameborder="no"border="0"marginwidth="0"marginheight="0"scrolling="no"allowtransparen

    2022年4月6日
    75
  • java获取Date时间的各种方式汇总「建议收藏」

    java获取Date时间的各种方式汇总「建议收藏」1. 常用的时间获取方式public class DateUtils {   /**   * 获取时间戳   * 输出结果:1438692801766   */  @Test  public void getTimeStamp() {    Date date = new Date();    long times = date.getTime();    System.o…

    2022年6月13日
    27

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号