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)
创建SqlSessionFacotry
创建SqlSession
创建Mapper
执行CRUD过程
实际上,Mybatis 只做了两件事情:1. 根据 JDBC 规范 建立与数据库的连接。
2. 通过反射打通Java对象和数据库参数和返回值之间相互转化的关系。
Hibernate: 是一个标准的 ORM 框架(对象关系映射)。学生成本较高,不需要编写sql语句,SQL语句自动生成。对于sql语句的优化,修改比较困难。
应用场景:
适合用于sql语句简单的,效率要求不是特别高的项目。
Mybatis: 专注于sql语句,对象映射和输入输出,都由框架帮你完成,所以属于半 ORM系统,
适用场景:
sql语句逻辑复杂,效率要求特别高的应用。