MyBatis常见的概念性面试题

MyBatis常见的概念性面试题

一.填空题

1.#{}和$ {}的区别是什么?#{}是_____,${}是_____。

正确答案: 预编译处理 字符串替换

2. MyBatis中提供了一级缓存和二级缓存,其中()默认存在,不可控制,同一SqlSession范围内的操作共享该缓存,增、删、改后将()。

正确答案:一级缓存 清除缓存

3.Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复? 不同的Xml映射文件,如果配置了namespace,那么id____;如果没有配置namespace,那么id____;

正确答案: 可以重复 不能重复

4.MyBatis是一款优秀的支持自定义SQL查询、存储过程和高级映射的()框架,几乎封装了所有的JDBC代码和参数的手动设置以及结果集的检索,通过XML或注解的方式进行配置映射实现数据库操作,大大提高了开发效率。

正确答案:持久层

二.多选题

1.对mybatis描述有误的是?

A. MyBatis 是一个可以自定义 SQL、存储过程和高级映射的持久层框架
B. MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面
C. Mybatis是一个全ORM(对象关系映射)框架,它内部封装了JDBC
D. MyBatis 只可以使用 XML来配置和映射原生信息
正确答案: C, D

2. Mybatis是如何将sql执行结果封装为目标对象并返回的

A. id
B. 标签
C. 使用sql列的别名
D. resultType
正确答案: B, C

3.mybaties中模糊查询like语句的写法

A. select * from foo where bar like #{value}
B. select * from foo where bar like #{%value%}
C. select * from foo where bar like %#{value}%
D. select * from foo where bar like “%”${value}"%"
正确答案: A, D

4.Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复? 选择说法正确的

A. 不同的Xml映射文件,如果配置了namespace,那么id可以重复
B. 如果没有配置namespace,那么id不能重复
C. 如果没有配置namespace,id能重复
D. 不同的Xml映射文件,如果配置了namespace,那么id不可以重复
正确答案: A, B

5.Mybatis的mapper接口调用时候的要求正确的是

A. Mapper接口方法名和Mapper.xml中定义的每个SQL的id相同;
B. Mapper接口方法的输入参数类型和mapper.xml中定义的每sqlparameterType类型相同
C. Mapper接口方法的输入输出参数类型和mapper.xml中定义的每个sqlresultType的类型相同
D. Mapper.xml文件中的namespace,就是接口的名字
正确答案: A, B, C

6.MyBatis内置类型别名有

A. _int
B. Integer
C. int
D. String
正确答案: A, C

7.Mybatis动态sql标签有哪些?

A. trim
B. foreach
C. set
D. than
正确答案: A, B, C

8.Mybaits的优点正确的是?

A. 基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL写在XML里,解除sql与程序代码的耦合,便于统一管理
B. 与JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接
C. 很好的与各种数据库兼容
D. 它是一全个ORM框架,MyBatis不需要程序员自己编写Sql语句。
正确答案: A, B, C

9.实体类中的属性名和表中的字段名不一样怎么处理?【选择二项】

A. 查询的sql语句中定义字段名的别名分数: 2
B. 不用处理
C. 通过来映射字段名和实体类属性名
D. 通过来映射字段名和实体类属性名
正确答案: A, C

三. 单选题

1.在mybatis的配置文件中,通过( )标签来设置实体类的别名。

A. properties
B. settings
C. typeAliases
D. dataSource
正确答案: C

2. 下列( )不属于 MyBatis全局配置文件中的标签

A. settings
B. select
C. plugins
D. properties
正确答案: B

3.在Mybatis中,SQL映射文件中配置insert语句时,在SQLSERVER中插入语句所在的表的ID为自动增长列,下列关于insert标签的说法,正确的是( )

A. 必须要显示插入标识列中的值
B. 使用任何数据库都可以使用自动生成主键策略
C. useGeneratedKeys属性对update标签也有作用
D. 可以使用useGeneratedKeys属性允许标识列的自动增长用于生成主键
正确答案: D

4.在 MyBatis 中,操作数据库的核心类是

A. SqlSessionFactory
B. SqlSession
C. Session
D. SqlSessionFactoryBuilder
正确答案: B

5. 在使用MyBatis的时候,除了可以使用@Param注解来实现多参数入参,还可以用()传递多个参数值。

A. 用Map对象可以实现传递多参数值
B. 用List对象可以实现传递多参数值
C. 用数组的方式传递
D. 用Set集合的方式传递
正确答案: A

6.在 MyBatis 中,配置结果映射时,使用( )标签实现多对1的关 联

A. many-one
B. one-many
C. association
D. collection
正确答案: C

7. MyBatis操作数据库时的接口方法中,如果传入的参数名和动态sql中使用时不一致,则需要使用( )注解修饰。

A. @RequestParam
B. @Parameter
C. @String
D. @Param
正确答案: D

8.在mybatis中,配置结果映射时,使用( )标签实现一对多的关 联

A. many-one
B. one-many
C. association
D. collection
正确答案: D

9.MyBatis 中对复杂数据映射到一个结果集的配置使用的标签是( )

A. < resultMap>
B. < result>
C. < map>
D. < collection>
正确答案: A

10. 在 MyBatis 动态 SQL 中,循环使用的标签名是( )。

A. for
B. while
C. foreach
D. do-while
正确答案: C

11. 看程序进行分析:Public UserselectUser(String name,String area);