【基于轻量型架构的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页。

相关推荐
MiyueFE6 分钟前
14 个逻辑驱动的 UI 设计技巧,助您改善任何界面
前端·设计
啃火龙果的兔子10 分钟前
前端单元测试覆盖率工具有哪些,分别有什么优缺点
前端·单元测试
「、皓子~38 分钟前
后台管理系统的诞生 - 利用AI 1天完成整个后台管理系统的微服务后端+前端
前端·人工智能·微服务·小程序·go·ai编程·ai写作
就改了40 分钟前
Ajax——在OA系统提升性能的局部刷新
前端·javascript·ajax
凌冰_42 分钟前
Ajax 入门
前端·javascript·ajax
京东零售技术1 小时前
京东小程序JS API仓颉改造实践
前端
老A技术联盟1 小时前
从小白入门,基于Cursor开发一个前端小程序之Cursor 编程实践与案例分析
前端·小程序
风铃喵游1 小时前
构建引擎: 打造小程序编译器
前端·小程序·架构
sunbyte1 小时前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | ThemeClock(主题时钟)
前端·javascript·css·vue.js·前端框架·tailwindcss
小飞悟1 小时前
🎯 什么是模块化?CommonJS 和 ES6 Modules 到底有什么区别?小白也能看懂
前端·javascript·设计