JAVA企业面试题精选 MyBatis 1-4

2.MyBatis

2.1.什么是MyBatis?

参考答案:

  MyBatis最早源自Apache基金会的一个开源项目iBatis,2010年这个项目由Apache software foundation迁移到了google code,并且改名为MyBatis;MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis封装了几乎所有的JDBC代码和参数的手工设置以及结果集的检索;MyBatis使用简单的XML或注解做配置和定义映射关系,将Java的POJOs(Plain Old Java Objects)映射城数据库中的记录.

2.2.简述MyBatis的体系结构

参考答案:

  MyBatis体系结构主要由以下几个关键部分;
  1.加载配置
  配置有两种形式,一种是XML配置文件,另一种是Java代码的注解.MyBatis将SQL的配置信息加载成为一个个的MappedStatement对象(包括了传入参数映射配置,执行的SQL语句,结果映射配置),并将其存储在内存中.
  2.SQL解析
  当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以使Map,JavaBean或者基本数据类型),MyBatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数.
  3.SQL执行
  将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果.
  4.结果映射
  将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap,JavaBean或者基本数据类型,并将最终结果返回.

2.3.列举MyBatis的常用API及方法

参考答案:

  在使用MyBatis框架时,主要涉及以下几个API:
  1.SqlSessionFactoryBuilder该对象负责根据MyBatis配置文件SqlMapConfig.xml构建SqlSessionFactory实例.
  2.SqlSessionFactory每一个MyBatis的应用程序都以一个SqlSessionFactory对象为核心.该对象负责创建SqlSession对象实例.
  3.SqlSession该对象包含了所有执行SQL操作的方法,用于执行SQL操作的方法,用于执行已映射的SQL语句.

2.4.对于Hibernate和MyBatis的区别与利弊,谈谈你的看法

参考答案:

  Hibernate与MyBatis的对比:
  1.MyBatis非常简单易学,与Hibernate相对较复杂,门槛较高;
  2.二者都是比较优秀的开源产品;
  3.当系统属于二次开发,无法对数据库结构做到控制和修改,那MyBatis的灵活性将比Hibernate更适合;
  4.系统数据处理量大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的SQL语句(或存储过程)才能达到系统性能设计指标.在这种情况下MyBatis会有更好的可控性和表现;
  5.MyBatis需要手写sql语句,也可以生成一部分,Hibernate则基本上可以自动生成,偶尔会写一些hql.同样的需求,MyBatis的工作量比Hibernate要大很多.类似的,如果涉及到数据库字段的修改,Hibernate修改的地方很少,而MyBatis要把那些sql mapping的地方–修改;
  6.MyBatis以数据库字段–对应映射得到的po和Hibernate这种对象化映射得到的po是截然不同的,本质区别在于这种po事扁平化的,不像Hibernate映射的po是可以表达立体的对象继承,聚合等等关系的,这将会直接影响到你的整个软件系统的设计思路;
  7.Hibernate现在已经是主流OR Mapping框架,从文档的丰富性,产品的完善性,版本的开发速度要强于MyBatis.

2.MyBatis

2.1.什么是MyBatis?

参考答案:

  MyBatis最早源自Apache基金会的一个开源项目iBatis,2010年这个项目由Apache software foundation迁移到了google code,并且改名为MyBatis;MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis封装了几乎所有的JDBC代码和参数的手工设置以及结果集的检索;MyBatis使用简单的XML或注解做配置和定义映射关系,将Java的POJOs(Plain Old Java Objects)映射城数据库中的记录.

2.2.简述MyBatis的体系结构

参考答案:

  MyBatis体系结构主要由以下几个关键部分;
  1.加载配置
  配置有两种形式,一种是XML配置文件,另一种是Java代码的注解.MyBatis将SQL的配置信息加载成为一个个的MappedStatement对象(包括了传入参数映射配置,执行的SQL语句,结果映射配置),并将其存储在内存中.
  2.SQL解析
  当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以使Map,JavaBean或者基本数据类型),MyBatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数.
  3.SQL执行
  将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果.
  4.结果映射
  将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap,JavaBean或者基本数据类型,并将最终结果返回.

2.3.列举MyBatis的常用API及方法

参考答案:

  在使用MyBatis框架时,主要涉及以下几个API:
  1.SqlSessionFactoryBuilder该对象负责根据MyBatis配置文件SqlMapConfig.xml构建SqlSessionFactory实例.
  2.SqlSessionFactory每一个MyBatis的应用程序都以一个SqlSessionFactory对象为核心.该对象负责创建SqlSession对象实例.
  3.SqlSession该对象包含了所有执行SQL操作的方法,用于执行SQL操作的方法,用于执行已映射的SQL语句.

2.4.对于Hibernate和MyBatis的区别与利弊,谈谈你的看法

参考答案:

  Hibernate与MyBatis的对比:
  1.MyBatis非常简单易学,与Hibernate相对较复杂,门槛较高;
  2.二者都是比较优秀的开源产品;
  3.当系统属于二次开发,无法对数据库结构做到控制和修改,那MyBatis的灵活性将比Hibernate更适合;
  4.系统数据处理量大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的SQL语句(或存储过程)才能达到系统性能设计指标.在这种情况下MyBatis会有更好的可控性和表现;
  5.MyBatis需要手写sql语句,也可以生成一部分,Hibernate则基本上可以自动生成,偶尔会写一些hql.同样的需求,MyBatis的工作量比Hibernate要大很多.类似的,如果涉及到数据库字段的修改,Hibernate修改的地方很少,而MyBatis要把那些sql mapping的地方–修改;
  6.MyBatis以数据库字段–对应映射得到的po和Hibernate这种对象化映射得到的po是截然不同的,本质区别在于这种po事扁平化的,不像Hibernate映射的po是可以表达立体的对象继承,聚合等等关系的,这将会直接影响到你的整个软件系统的设计思路;
  7.Hibernate现在已经是主流OR Mapping框架,从文档的丰富性,产品的完善性,版本的开发速度要强于MyBatis.

猜你喜欢

转载自blog.csdn.net/a639735331/article/details/81699600