java面试回忆总结之-----mybatis工作原理以及为什么使用,怎么使用

mybatis底层还是采用原生jdbc来对数据库进行操作的,只是通过 SqlSessionFactory,SqlSession Executor,StatementHandler,ParameterHandler,ResultHandler和TypeHandler等几个处理器封装了这些过程

执行器:Executor (update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)

参数处理器: ParameterHandler (getParameterObject, setParameters)

结果处理器 ResultSetHandler (handleResultSets, handleOutputParameters)

sql查询处理器:StatementHandler (prepare, parameterize, batch, update, query)

java面试回忆总结之-----mybatis工作原理以及为什么使用,怎么使用


创建SqlSessionFacotry

创建SqlSession

创建Mapper

执行CRUD过程

实际上,Mybatis 只做了两件事情: 
1. 根据 JDBC 规范 建立与数据库的连接。 

2. 通过反射打通Java对象和数据库参数和返回值之间相互转化的关系。


Hibernate: 是一个标准的 ORM 框架(对象关系映射)。学生成本较高,不需要编写sql语句,SQL语句自动生成。对于sql语句的优化,修改比较困难。 
应用场景: 
适合用于sql语句简单的,效率要求不是特别高的项目。

Mybatis: 专注于sql语句,对象映射和输入输出,都由框架帮你完成,所以属于半 ORM系统, 
适用场景: 

sql语句逻辑复杂,效率要求特别高的应用。