15、 MyBatis实现一对一有几种方式?具体怎么操作的?
有联合查询和嵌套查询,联合查询是几个表联合查询,只查询一次,通过在 resultMap里面配置association节点配置一对一的类就可以完成;嵌套查询 是先查一个表,根据这个表里面的结果的外键id,去再另外一个表里面查询 数据,也是通过association配置,但另外一个表的查询通过select属性配 置。
16、 Mybatis能执行一对一、一对多的关联查询吗?都有哪些实现方式, 以及它们之间的区别?
能,Mybatis不仅可以执行一对一、一对多的关联查询,还可以执行多对―,多对多的关联查询,多对一查询,其实就是一对一查询,只需要把 selectOne。修改为selectList。即可;多对多查询,其实就是一对多查询,只 需要把selectOne。修改为selectList。即可。
关联对象查询,有两种实现方式,一种是单独发送一个sql去查询关联对 象,赋给主对象,然后返回主对象。另一种是使用嵌套查询,嵌套查询的 含义为使用join查询,一部分列是A对象的属性值,另外一部分列是关联 对象B的属性值,好处是只发一个sql查询,就可以把主对象和其关联对 象查出来。
17、 MyBatis里面的动态Sql是怎么设定的?用什么语法?
MyBatis里面的动态Sql 一般是通过if节点来实现,通过OGNL语法来实现,但是如果要写的完整,必须配合where,trim节点,where节点是判断包含 节点有内容就插入where,否则不插入,trim节点是用来判断如果动态语句是 以and或or开始,那么会自动把这个and或者or取掉。
18、 Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式?
第一种是使用<resultMap>标签,逐一定义列名和对象属性名之间的映射关系。
第二种是使用sql列的别名功能,将列别名书写为对象属性名,比如T_NAME AS NAME,对象属性名一般是name,小写,但是列名不区分大小写,Mybatis会忽略列名大小写,智能找到与之对应对象属性名,你甚至可以写成 T_NAME AS NaMe, Mybatis 一样可以正常工作。有了列名与属性名的映射关系后,Mybatis通过反射创建对象,同时使用反射给对象的属性逐一赋值并返回,那些找不到映射关系的属性,是无法完成赋值的。
19、 Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签?
还有很多其他的标签,<resultMap>、<parameterMap>、<sql>、 〈include〉、<selectKey>,加上动态 sql 的 9 个标签, trim|where|set|foreach|if|choose|when|otherwise|bind 等,其 中<sql>为sql片段标签,通过<include>标签引入sql片
段,<selectKey>为不支持自增的主键生成策略标签。
20、 当实体类中的属性名和表中的字段名不一样,如果将查询的结果封装到指定pojo?
21、 模糊查询like语句该怎么写
22、 通常一个Xml映射文件,都会写一个Dao接口与之对应,Dao的工作原理,是否可以重载?
不能重载,因为通过Dao寻找Xml对应的sql的时候全限名+方法名的保存和寻找策略。接口工作原理为jdk动态代理原理,运行时会为dao生成 proxy,代理对象会拦截接口方法,去执行对应的sql返回数据。
23、 Mybatis映射文件中,如果A标签通过include引用了 B标签的内 容,请问,B标签能否定义在A标签的后面,还是说必须定义在A标签的前面?
虽然Mybatis解析Xml映射文件是按照顺序解析的,但是,被引用的B标 签依然可以定义在任何地方,Mybatis都可以正确识别。原理是,Mybatis 解析A标签,发现A标签引用了 B标签,但是B标签尚未解析到,尚不 存在,此时,Mybatis会将A标签标记为未解析状态,然后继续解析余下的标签,包含B标签,待所有标签解析完毕,Mybatis会重新解析那些被 标记为未解析的标签,此时再解析A标签时,B标签已经存在,A标签也就可以正常解析完成了。
24、 Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?
不同的Xml映射文件,如果配置了 namespace,那么id可以重复;如果没 有配置namespace,那么id不能重复;毕竟namespace不是必须的,只 是最佳实践而已。原因就是namespace+id是作为Map<String, MappedStatement>的key使用的,如果没有namespace,就剩下id,那 么,id重复会导致数据互相覆盖。有了 namespace,自然id就可以重复,namespace不同,namespace+id自然也就不同。
25、 Mybatis中如何执行批处理?
使用BatchExecutor完成批处理。
26、 Mybatis都有哪些Executor执行器?它们之间的区别是什么?
Mybatis 有三种基本的 Executor 执行器,SimpleExecutor、 ReuseExecutor、 BatchExecutor。
1. SimpleExecutor:每执行一次 update 或 select,就开启一个 Statement对象,用完立刻关闭 Statement对象。
2.ReuseExecutor :执行 update 或 select,以 sql 作为 key 查找 Statement 对象,存在就使用,不存在就创建,用完后,不关闭Statement对象,而是放置于Map
3.BatchExecutor:完成批处理。
27、 Mybatis中如何指定使用哪一种Executor执行器?
在Mybatis配置文件中,可以指定默认的ExecutorType执行器类型,也可以手动给DefaultSqlSessionFactory的创建SqlSession的方法传递 ExecutorType 类型参数。
28、 Mybatis执行批量插入,能返回数据库主键列表吗?
能,JDBC都能,Mybatis当然也能。
29、 Mybatis是否可以映射Enum枚举类?
Mybatis可以映射枚举类,不单可以映射枚举类,Mybatis可以映射任何对象到表的一列上。映射方式为自定义一个TypeHandler,实现TypeHandler的 setParameter()和 getResult()接口方法。TypeHandler有两个作用,一是完成从javaType至jdbcType的转换,二 是完成 jdbcType 至 javaType 的转换,体现为 setParameter。和 getResult。 两个方法,分别代表设置sql问号占位符参数和获取列查询结果。
30、 如何获取自动生成的(主)键值?
配置文件设置usegeneratedkeys为true
31、 在mapper中如何传递多个参数?
答:
32、 resultType resultMap 的区别?
33、 使用MyBatis的mapper接口调用时有哪些要求?
类型相同
1. Mapper接口方法名和mapper.xm l中定义的每个sql的id相同
2.Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的 parameterType的类型相同
3.Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的 resultType的类型相同
4.Mapper.xml文件中的namespace即是mapper接口的类路径。
34、 Mybatis比旧atis比较大的几个改进是什么?
- 有接口绑定,包括注解绑定sql和xml绑定Sql
- 动态sql由原来的节点配置变成OGNL表达式
- 在一对一,一对多的时候引进了 association,在一对多的时候引入了 collection节点,不过都是在resultMap里面配置
35、 IBatis和MyBatis在核心处理类分别叫什么?
IBatis里面的核心处理类交SqlMapClient,MyBatis里面的核心处理类叫做 SqlSession。
36、 IBatis和MyBatis在细节上的不同有哪些?