mybatis是什么?其优缺点是什么?
mybatis是ORM框架,提供Java Object到数据库Relation操作的映射,同时提供对JDBC的操作的包装和优化,包括连接池的优化、缓存的优化、事务管理等。
通过构建mapper映射接口和xml配置文件,可以很灵活的做好java实体类和jdbc实体间的映射操作;
- mybatis的架构和原理?
mybatis的架构主要分为三层:
- 接口层:主要是向外提供增删改查的接口。
- 数据处理层:主要就是sql和参数传入到结果传出的过程,包括的流程有参数映射、SQL解析、SQL执行、结果映射;
- 支撑层:主要负责数据库的连接、事务管理、配置加载还有缓存管理等功能。
mybatis的处理流程包括:
- 读取配置文件,生成配置项。通过读取mybati-config.xml配置文件和mapper文件,生成配置项MappedStatement;
- 构建会话工厂sqlSessionFactory;这个是mybatis根据configuration来生成的;
- 通过sqlSessionFactory构建sqlSession,其中sqlSession就对应一个mapper文件。
- 通过执行器Executor来执行解析后的sql;其中每个sql会包装成一个mappedStatement;
一文搞懂Mybatis架构与工作原理:
- mybatis的缓存机制?
mybatis有二级缓存管理机制;
- 一级缓存管理:在Executor查询database之前,会查询本地缓存,由于每个sqlSession有自己的Executor,所以每个Executor有自己的LocalCache,该缓存查询的key值根据statementId、params、rowBound共同决定;
- 二级缓存管理:由于一级缓存知识针对单个sqlSession,针对不同的sqlSession可以配置二级缓存对象,实现多个sqlSession间的缓存共享,可以自己实现cache类也可以引入第三方的缓存服务;
- mybatis中xml映射文件#{}和${}的区别是什么?
- #{}的是在数据库预编译阶段处理,调用PreparedStatement的set方法将#{}占位符替换成?
- ${}的处理只是用值替换掉该占位符。使用${}可能有sql注入的风险。
总结:在使用order by和group by语句时,必须要使用${}
- mybatis中数据库字段名和实体属性名如何映射?
Mybatis查询数据库的结果会保存在ResultSet中,然后将该对象映射到Java对象中,其映射的方式包括以下几种:
- 通过数据库字段名和实体属性名映射。这个是默认的映射方式。
- 通过设置别名。如果sql语句中设置了别名,会优先使用数据库别名和Java实体属性名进行映射。
- 通过ResultMap来设置据库字段名和实体属性名的映射。
<resultMap id="BaseResultMap" type="com.yangnk.mysqldemo.entity.User1" > <id column="id" property="id" jdbcType="INTEGER" /> <result column="user_name" property="userName" jdbcType="VARCHAR" /> <result column="password" property="password" jdbcType="VARCHAR" /> <result column="sex" property="sex" jdbcType="VARCHAR" /> </resultMap> |
- 可以自定义TypeHandler,如果以上配置的映射方式无法满足需求,可以自定义TypeHandler来实现数据库字段名和实体属性名之间的映射。
- mybatis如何实现分页?
- 可以在sql中进行limit限制,进行物理分页,也是比较推荐的,一般分页插件是通过这种方式来实现的,通过mybatis提供的插件机制,通过filter拦截sql,对其进行改造,再执行;
- 另一种是mybatis自带的分页特性,他主要是通过内存分页来实现的,就是再查询出所有结果到内存中后,再进行内存分页。这个是通过RowBound来实现的,其中指定了offset和limit参数,在全部查询出数据后再进行内存分页。
- mybatis实现动态SQL的原理?
动态SQL是指可以根据不同的条件生成不同的SQL,这个主要可以通过标签来实现,包括常见的if标签、foreach标签、when标签等。
- mybatis的Mapper接口为什么没有实现类还能调用?
通过JDK动态代理的方式实现了对目标对象的操作,其实是调用MapperProxy的invoke方法。
- Mybatis和Hibernate的区别?
Mybatis和Hibernate都是经典的ORM框架,便于Java对象直接操作数据库,他们都能够支持事务管理和缓存管理等特性。
他们的主要区别如下:
- Mybatis是半自动的框架,Hibernate是全自动的框架。Mybatis的sql语句需要自己编写,可以编写更复杂和灵活的sql;Hibernate只要配置好数据库关系和Java DO的关系,之后的增删改查操作都能通过Hibernate自动完成。
- Mybatis更加灵活和高效,由于其能够自定义sql,所以适应的场景更多;Hibernate相对来说更容易入手,针对只需要简单增删改查的场景是比较方便的。