简述Mybatis框架

1. Mybatis和JDBC的关系

  • 我们知道JDBC是Java提供的一个操作数据库的API,但在平时的使用中,若直接使用JDBC操作数据库的话,操作上未免有些繁琐,所以为了简化开发,我们基本都会选择使用一个ORM框架来帮助我们来操作数据库。
  • ORM的全称是Object Relational Mapping,即对象关系映射。描述的是对象和表之间的映射。操作Java对象,通过映射关系,就可以自动操作数据库。在ORM关系中,数据库表对应Java中的类,一条记录对应一个对象,一个属性对应一个列。
  • Java 使用的主流ORM框架:
    • Hibernate
    • MyBatis

2. Mybatis是什么?

  • mybatis是一个持久层ORM框架。它内部封装了jdbc,使得开发更简洁,更高效。
  • Mybatis使开发者只需要关注sql语句本身,Mybatis可以通过xml或注解完成ORM映射关系配置,简化JDBC操作,不需要在关注加载驱动、创建连接、处理SQL语句等繁杂的过程。
  • MyBatis对JDBC操作数据库做了一系列的优化:
    • mybatis使用已有的连接池管理,避免浪费资源,提高程序可靠性。
    • mybatis提供插件自动生成DAO层代码,提高编码效率和准确性。
    • mybatis 提供了一级和二级缓存,提高了程序性能。
    • mybatis使用动态SQL语句,提高了SQL维护。
    • mybatis对数据库操作结果进行自动映射
      简述Mybatis框架

3. Mybatis与Hibernate的区别

  • Hibernate是一个开放源代码的对象关系映射框架。是一个全自动的、完全面向对象的持久层框架。也就是使用hibernate不用编写任何SQL语句。关联对象直接调用对应方法,可以自动完成数据的查询。
  • MyBatis是一个开源对象关系映射框架,原名:ibatis,2010年由谷歌接管以后更名。底层封装了JDBC基本操作,但仍需要编写SQL语句,也称为半自动化持久层ORM框架。使用通过Mapper可以简化MyBatis单表操作,多表仍需要自己编写SQL语句。

4. Mybatis中#{}和${}的区别

  • #{} 实现的是sql语句的预处理参数,之后在sql中用?号代替,使用时不需要关注数据类型,Mybatis自动实现数据类型的转换,并且可以防止SQL注入。
  • ${} 实现的是sql语句的直接拼接,不做数据类型转换,需要自行判断数据类型,不能防止SQL注入。
  • #{}占位符,用于参数传递; ${}用于SQL拼接。

5. 属性名和字段名对应

  • 在使用Mybatis过程中,当实体类中的属性名和表中的字段名不一样时的解决方法:
    • 通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致
    • 使用通用Mapper时,可以通过@Column注解设置
    • 如果进行自定义查询,可以通过@Result进行设置
    • 如果使用的xml配置,通过< resultMap>进行配置

6. Mybatis分页

  • 原理: Mybatis分页使用MyBatis插件(也称为拦截器)机制,对需要使用分页的功能进行增强。也就是重写SQL,根据不同的数据库生产不同的分页语句。(Mysql生成limit语句,Oracle借助rownum生产对应子查询语句)
  • 使用: Mybatis分页时使用第三方分页助手:PageHelper。使用方式:在将要执行查询sql语句之前使用分页助手:PageHelper.startPage(pageNum:页码, pageSize:每页显示数量);

7. Mybatis的缓存机制

  • Mybatis的缓存机制分为一级缓存和二级缓存:
    • 一级缓存:一级缓存的作用域是sqlSession会话级,相当于JDBC的Connection连接。一级缓存默认开启,用户不能手动配置。当在同一个sqlSession中执行两次相同的sql语句时,第一次执行完毕会将数据库中查询的数据写到缓存(内存)中,第二次查询时会直接从缓存中获取数据,不再去底层数据库查询,从而提高查询效率;
    • 二级缓存:二级缓存的作用域为同一个mapper的namespace,是跨sqlSession的,同一个namespace中不同的查询SQL可以在二级缓存中存取查询结果。二级缓存默认关闭,可以通过配置进行开启。二级缓存的对象必须序列化,例如:User对象必须实现Serializable接口。
    • Mybatis中,执行select时,查询数据会被缓存;当执行insert、update、delete等操作的时候,缓存则会被清除