【基于轻量型架构的WEB开发】课程 作业2 mybatis关联查询、缓存、注解

作业2 mybatis关联查询、缓存、注解

一、单选题

1. <collection>元素的使用

题目:下列关于<collection>元素的描述正确的是()。

  • A. MyBatis就是通过<collection>元素来处理一对多关联关系的
  • B. <collection>元素的属性与<association>元素完全相同
  • C. <collection>元素只能使用嵌套查询方式
  • D. ofType属性与javaType属性对应,它用于指定实体对象中所有属性所包含的元素类型

答案:A

解析:MyBatis通过<collection>元素处理一对多关联关系。

B选项错误,因为association使用javaType属性,而collection使用ofType属性。

C选项错误,因为<collection>元素可以使用嵌套查询或嵌套结果方式。

D选项错误,因为ofType用于指定集合类型所包含的元素的类型。

2. @Insert注解的使用

题目:关于@Insert注解的使用,下列代码书写正确的是()。

  • A. Insert("insert into tb_worker(name,age,sex,worker_id) values(#{name},#{age},#{sex},#{worker_id})") int insertWorker(Worker worker);
  • B. @Insert("insert into tb_worker(name,age,sex,worker_id) values(#{name},#{age},#{sex},#{worker_id})") int insertWorker(Worker worker);
  • C. @Insert("insert into tb_worker(name,age,sex,worker_id) values(#{name} #{age} #{sex} #{worker_id})") int insertWorker(Worker worker);
  • D. @Insert("insert into tb_worker(name,age,sex,worker_id) values({name},{age},{sex},{worker_id})") int insertWorker(Worker worker);

答案:B

解析选项 B :正确使用了 @Insert 注解,并且 SQL 语句中的占位符格式正确。

选项 A:缺少了 @ 符号,导致 Insert 注解无效。

选项 C:虽然使用了 @Insert 注解,但在 SQL 语句中的占位符之间缺少逗号,导致 SQL 语法错误。

选项 D:虽然使用了 @Insert 注解,但在 SQL 语句中的占位符格式错误,应使用 #{} 而不是 {}

3. @Select注解的使用

题目:要求根据员工的id查找员工信息,下列使用@Select注解的代码书写正确的是()。

  • A. @Select("select * from tb_worker where id = #{id}")
  • B. @Select("select * from tb_worker where id = #id")
  • C. @Select("select * from tb_worker where id = ?")
  • D. @Select("select * from tb_worker where id = {id}")

答案:A

解析 :正确的写法是@Select("select * from tb_worker where id = #{id}")

B选项和D选项的参数绑定方式不正确。

C选项使用了问号占位符,这在MyBatis中不适用。

二、判断题

4. @Insert注解的作用

题目:MyBatis的@Insert注解就是将SQL语句直接写在接口上,使得代码书写更加简单,减少了大量的XML文件的配置。

答案:对

5. 核心配置文件的扫描方式

题目:MyBatis中,核心配置文件中的内容的扫描方式是从上到下扫描。

答案:对

解析:MyBatis 在启动时会从上到下依次读取核心配置文件中的配置项。

6. 多对多关联映射

题目:MyBatis中多对多关联映射同样有嵌套查询和嵌套结果两种关联方式。

答案:对

7. 一级缓存的行为

题目:MyBatis一级缓存被清空之后,再次使用SQL查询语句访问数据库时,MyBatis会重新访问数据库。

答案:对

8. 关联关系中的外键

题目:关系型数据库的关联关系中,在"一"的一方,添加"多"的一方的主键作为外键。

答案:错

解析:应该在"多"的一方添加"一"方的主键为外键。

9. @Param注解的功能

题目:MyBatis中,@Param注解的功能是指定SQL语句中的参数,通常用于SQL语句中参数比较多的情况。

答案:对

10. @Update注解的参数

题目:MyBatis中,@Update注解的参数可以是一条插入语句,也可以是一条更新语句。

答案:对

解析:@Update注解通常用于映射更新或删除类型的SQL语句,也可以用于执行插入语句。

在MyBatis中,@Update 注解通常用于映射更新(UPDATE)或删除(DELETE)类型的SQL语句。虽然它的名称是 @Update,但它不仅仅局限于更新操作,也可以用于执行插入(INSERT)语句。

11. 多对多关联关系的维护

题目:在数据库中,表与表之间的多对多关联关系通常使用一个中间表来维护。

答案:对

解析:E-R图中的多对多联系转换为关系模型时,是转换成一个表。

12. <association>元素的配置方式

题目:<association>元素只有一种配置方式,即嵌套结果方式。

答案:错

解析:还可以用嵌套查询的方式。

13. @Results注解的使用

题目:在@Results注解中,可以包含多个@Result注解,一个@Result注解完成实体类中一个属性和数据表中一个字段的映射。

答案:对

解析:见教材75页。

三、填空题

14. <association>元素的【】属性用于指定引入嵌套查询的子SQL语句。

答案:select

15. 在@Result注解中,【】属性用来指定POJO中的关联属性。

答案:property

16. MyBatis的二级缓存是【】级别的缓存。

答案:Mapper

17. <collection>元素的属性中,用于指定实体类对象中集合类属性所包含的元素类型的是【】。

答案:ofType

18. 在使用<association>元素时,它的fetchType属性有【】和eager两个属性值。

答案:lazy

解析:见教材45页,lazy表示关联映射延迟加载,eager表示不延迟加载。

19. MyBatis使用【】注解实现数据表的一对多关联查询,它作用等同于XML配置文件中的<collection>元素。

答案:@Many

20. 【】注解用于映射删除语句,其作用等同于XML配置文件中的<delete>元素。

答案:@Delete

四、多选题

21. <cache>元素的eviction属性可选值

题目:下列属于<cache>元素的eviction属性可选值的是()。

  • A. FIFO
  • B. LRU
  • C. SOFT
  • D. WEAK

答案:ABCD

解析:eviction设置缓存的收回策略,见教材67页。

相关推荐
m0_748255262 分钟前
easyExcel导出大数据量EXCEL文件,前端实现进度条或者遮罩层
前端·excel
新手小袁_J15 分钟前
JDK11下载安装和配置超详细过程
java·spring cloud·jdk·maven·mybatis·jdk11
web1478621072335 分钟前
C# .Net Web 路由相关配置
前端·c#·.net
m0_7482478036 分钟前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖40 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案11 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_748254881 小时前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
小屁不止是运维1 小时前
麒麟操作系统服务架构保姆级教程(五)NGINX中间件详解
linux·运维·服务器·nginx·中间件·架构
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营1 小时前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis