关于mybatis面试题总结

关于mybatis面试题总结

**1. 在 MyBatis 中,操作数据库的核心类是(SqlSession)
2. MyBatis操作数据库时的接口方法中,如果传入的参数名和动态sql中使用时不一致,则需要使用( @Param)注解修饰
3. MyBatis 中,配置结果映射时,使用(association )标签实现多对1的关联
4. 在 MyBatis中调用SqlSessionFactoryBuilder的( openSession())方法用于获取SqlSession对象。
5. MyBatis对JDBC访问数据库的代码进行封装,从而大大简化了数据访问层的重复性代码,它是针对三层架构中( 持久化层)的解决方案
6. >下图是MyBatis的一张架构图,来自Java框架篇—Mybatis 入门。关于mybatis面试题总结_第1张图片
7. 使用MyBatis的mapper接口调用时有哪些要求:
Mapper接口方法名和mapper.xml中定义的每个sql的id相同
Mapper.xml文件中的namespace即是mapper接口的类路径
Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同;
Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同;
8. MyBatis内置类型别名有:int和_int

  1. Mybatis用(1.《resultMap>标签
    2.使用sql列的别名)将sql执行结果封装为目标对象并返回的
  2. 如何获取自动生成的(主)键值:设置keyProperty
  3. 想实现批量删除的动态sql的标记可选择? Foreach
  4. 模糊查询like语句该怎么写?
    第1种:在Java代码中添加__ sql通配符
    第2种:在sql语句中添加_拼接通配符
    _,会引起sql注入
  5. MyBatis是一款优秀的支持自定义SQL查询、存储过程和高级映射的(持久层)框架,几乎封装所有的JDBC代码和参数的手动设置以及结果集的检索,通过XML或注解的方式进行配置映射实现数据库操作,大大提高了开发效率。
  6. 四个核心接口是(Executor )用于执行CRUD操作、( ParameterHandler)处理SQL的参数、(ResultSetHandler)处理返回结果集、( StatementHandler)用于执行SQL语句。
  7. MyBatis中提供了一级缓存和二级缓存,其中(一级缓存)默认存在,不可控制,同一SqlSession范围内的操作共享该缓存,增、删、改后将(清除缓存)。**

15、#{}和${}的区别是什么?

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

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

Mybatis在处理 时 , 就 是 把 {}时,就是把 {}替换成变量的值。

使用#{}可以有效的防止SQL注入,提高系统安全性。

16、当实体类中的属性名和表中的字段名不一样 ,怎么办 ?

第1种: 通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致。

  <select id=”selectorder” parametertype=int” resultetype=”me.gacl.domain.order”>
       select order_id id, order_no orderno ,order_price price form orders where order_id=#{id};
    </select>

第2种: 通过来映射字段名和实体类属性名的一一对应的关系。

 <select id="getOrder" parameterType="int" resultMap="orderresultmap">
        select * from orders where order_id=#{id}
    </select>
 
   <resultMap type=”me.gacl.domain.order” id=”orderresultmap”>
        <!–用id属性来映射主键字段–>
        <id property=”id” column=”order_id”>
 
        <!–用result属性来映射非主键字段,property为实体类属性名,column为数据表中的属性–>
        <result property = “orderno” column =”order_no”/>
        <result property=”price” column=”order_price” />
    </reslutMap>

1、什么是Mybatis?

(1)Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。程序员直接编写原生态sql,可以严格控制sql执行性能,灵活度高。

(2)MyBatis 可以使用 XML 或注解来配置和映射原生信息,将 POJO映射成数据库中的记录,避免了几乎所有的 JDBC
代码和手动设置参数以及获取结果集。

(3)通过xml 文件或注解的方式将要执行的各种 statement 配置起来,并通过java对象和
statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。(从执行sql到返回result的过程)。

2、Mybaits的优点:

(1)基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL写在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL语句,并可重用。

(2)与JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接;

(3)很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据库MyBatis都支持)。

(4)能够与Spring很好的集成;

(5)提供映射标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签,支持对象关系组件维护。

3、MyBatis框架的缺点:

(1)SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求。

(2)SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。

5、MyBatis与Hibernate有哪些不同?

(1)Mybatis和hibernate不同,它不完全是一个ORM框架,因为MyBatis需要程序员自己编写Sql语句。

(2)Mybatis直接编写原生态sql,可以严格控制sql执行性能,灵活度高,非常适合对关系数据模型要求不高的软件开发,因为这类软件需求变化频繁,一但需求变化要求迅速输出成果。但是灵活的前提是mybatis无法做到数据库无关性,如果需要实现支持多种数据库的软件,则需要自定义多套sql映射文件,工作量大。

(3)Hibernate对象/关系映射能力强,数据库无关性好,对于关系模型要求高的软件,如果用hibernate开发可以节省很多代码,提高效率。

一些关于缓存的笔记:

–缓存Cache
减轻数据库压力,提高查询效率
一级缓存在操作数据库时需要构造sqlSessin对象,不同的sqlSessin之间互不影响
二级缓存多个sqlSessin可以共用二级缓存,二级缓存时跨sqlSessin
一级缓存是默认使用的
二级缓存是需要开启的

一个关于MyBatis-Plus使用的官网链接:https://mybatis.plus/

你可能感兴趣的:(关于mybatis面试题总结)