Mybatis

1.    MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架,MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索,MyBatis使用简单的XML或注解用于配置和原始映射,将接口与Java的POJOs(plan old object,普通的java对象)映射成数据库中的记录。

2.    MyBatis的功能架构分为三层:

API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。

数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。

基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件,为上层的数据处理层提供最基础的支撑。

3.    流程:

MyBatis的应用程序入口是SqlSessionFactoryBuilder

4.    #{}和${}的区别:#{}是预编译处理,${}是字符串替换;Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用preparedStatement的set方法来赋值;Mybatis在处理${}时,就是把${}替换成变量的值;使用#{}可以有效防止sql注入,提高系统安全性。

5.    当实体类中的属性名和表中的字段名不一样:a.通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致;b.通过来映射字段名和实体类属性名的一一对应的关系。

6.    通过一个XML映射文件,都会写一个Dao接口与之对应,请问这个 Dao接口的工作原理是什么?Dao接口里的方法,参数不同,方法能重载吗?

Dao接口就是人们常说的Mapper接口,接口的全限名,就是映射文件中的namespace的值,接口的方法名,就是映射文件中MappedStatement的id值,接口方法内的参数就是传递sql的参数。Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key的值,可唯一定位一个MappedStatement,举例:com.mybatis3.mappers.StudentDao.findStudentById,可以唯一找到namespace为com.mybatis3.mappers.StudentDao下面id=findStudentById的MappedStatement。在Mybatis中,每一个