首页 > 其他分享 >02-面试必会-SSM框架篇

02-面试必会-SSM框架篇

时间:2023-05-14 17:02:46浏览次数:34  
标签:02 Spring sql SSM bean 必会 Mybatis 注解 注入

01-什么是 Spring IOC 和 DI ?

IOC : 控制翻转 , 它把传统上由程序代码直接操控的对象的调用权交给容 器,通过容器来实现对象组件的装配和管理。所谓的“控制反转”概念就是对组件对象控制权的转 移,从程序代码本身转移到了外部容器。

DI : 依赖注入,在我们创建对象的过程中,把对象依赖的属性注入到我们的类中。

02-有哪些不同类型的依赖注入实现方式?

依赖注入分为接口注入,Setter 方 法注入和构造器注入以及注解注入

  • 构造器注入 : 顾名思义, 就是在类中提供有参构造方法, 创建 Bean 的时候会自动执行构造方法将依赖数据注入进去

  • Setter 方法注入 : 顾名思义, 就是提供属性对应的 setter 方法 , 创建 Bean 的时候会自动执行 Setter 方法将依赖数据注入进去

  • 注解注入 : 就是在属性上使用一些注入注入数据, 经常用的有 @Autowired , @Resource ,@Qualifier 注解

    @Autowired : 默认根据类型注入 , 按照类型匹配多个 Bean,再按照属性名称注入

    @Resource : 默认按照名称注入 , 如果找不到对应的 Bean,按照类型注入 , 也可以指定按照名称注入(name)或者按照类型注入(type)

    @Qualifier : 结合@Autowired 注解一起使用, 如果按照类型匹配多个 Bean , 通过@Qualifier 注解指定按照名称注入的属性名称

03- Spring 支持的几种 bean 的作用域 Scope

Spring 框架支持以下五种 bean 的作用域:

  • singleton : bean 在每个 Spring ioc 容器中只有一个实例。

  • prototype:一个 bean 的定义可以有多个实例。

  • request:每次 http 请求都会创建一个 bean,该作用域仅在基于 web 的 Spring ApplicationContext 情形下有效。

  • session:在一个 HTTP Session 中,一个 bean 定义对应一个实例。该作用域仅在基于 web 的 Spring ApplicationContext 情形下有效。

  • global-session:在一个全局的 HTTP Session 中,一个 bean 定义对应一个实例。该作用域仅在基 于 web 的 Spring ApplicationContext 情形下有效。

04- Spring 框架中的单例 bean 是线程安全的吗?

不是,Spring 框架中的单例 bean 不是线程安全的 , spring 中的 bean 默认是单例模式,spring 框架并没有对单例 bean 进行多线程的封装处理。

但是我们一般在使用单例 Bean 的时候, 不会设置共享数据, 所以也就不会存在线程安全问题 ! 从这个角度讲单例 bean 也是线程安全的

05- spring 自动装配 bean 有哪些方式?

在 Spring 框架 xml 配置中共有 5 种自动装配:

  • byName:通过 bean 的名称进行自动装配,如果一个 bean 的 property 与另一 bean 的 name 相 同,就进行自动装配。
  • byType:通过参数的数据类型进行自动装配。
  • constructor:利用构造函数进行装配,并且构造函数的参数通过 byType 进行装配。
  • setter 方法 : 根据属性的 setter 方法注入
  • 注解注入

09- JDK 动态代理和 CGLIB 动态代理的区别

Spring AOP 中的动态代理主要有两种方式,JDK 动态代理和 CGLIB 动态代理:

  • JDK 动态代理只提供接口的代理,不支持类的代理

    Proxy.newProxyInstance(类加载器, 代理对象实现的所有接口, 代理执行器)
    
  • CGLIB 是通过继承的方式做的动态代理 , 如果某个类被标记为 final,那么它是无法使用 CGLIB 做动态代理的。

    Enhancer.create(父类的字节码对象, 代理执行器)
    

10- 什么是 AOP , 你们项目中有没有使用到 AOP

AOP 一般称为面向切面编程,作为面向对象的一种补充,用于 将那些与业务无关,但却对多个对象产生影响的公共行为和逻辑,抽取并封装为一个可重用的模 块,这个模块被命名为“切面”(Aspect),减少系统中的重复代码,降低了模块间的耦合度,同时 提高了系统的可维护性。

在我们的项目中我们自己写 AOP 的场景其实很少 , 但是我们使用的很多框架的功能底层都是 AOP , 例如 : 权限认证、日志、事务处理等

11- SpringMVC 的执行流程知道嘛

1550741934406

  1. 用户发送请求至前端控制器 DispatcherServlet;
  2. DispatcherServlet 收到请求后,调用 HandlerMapping 处理器映射器,请求获取 Handle;
  3. 处理器映射器根据请求 url 找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生 成)一并返回给 DispatcherServlet;
  4. DispatcherServlet 调用 HandlerAdapter 处理器适配器;
  5. HandlerAdapter 经过适配调用具体处理器(Handler,也叫后端控制器);
  6. Handler 执行完成返回 ModelAndView;
  7. HandlerAdapter 将 Handler 执行结果 ModelAndView 返回给 DispatcherServlet;
  8. DispatcherServlet 将 ModelAndView 传给 ViewResolver 视图解析器进行解析;
  9. ViewResolver 解析后返回具体 View;
  10. DispatcherServlet 对 View 进行渲染视图(即将模型数据填充至视图中)
  11. DispatcherServlet 响应用户

12- Spring MVC 常用的注解有哪些?

@RequestMapping:用于处理请求 url 映射的注解,可用于类或方法上。用于类上,则表示类中 的所有响应请求的方法都是以该地址作为父路径。

@RequestBody:注解实现接收 http 请求的 json 数据,将 json 转换为 java 对象。

@ResponseBody:注解实现将 conreoller 方法返回对象转化为 json 对象响应给客户。

@Controller:控制器的注解,表示是表现层,不能用用别的注解代替

@RestController : 组合注解 @Conntroller + @ResponseBody

@GetMapping , @PostMapping , @PutMapping , @DeleteMapping ...

@PathVariable : 接收请求路径中的变量

@RequestParam : 接收请求参数

13- Mybatis #{}和${}的区别

#{}是占位符,预编译处理;${}是拼接符,字符串替换,没有预编译处理。

Mybatis 在处理#{}时,#{}传入参数是以字符串传入,会将 SQL 中的#{}替换为?号,调用 PreparedStatement 的 set 方法来赋值。

#{} 可以有效的防止 SQL 注入,提高系统安全性;${} 不能防止 SQL 注入

#{} 的变量替换是在数据库系统中; ${} 的变量替换是在 数据库系统外

14- Mybatis 如何获取生成的主键

我知道的有二种方式

  1. 在 insert 标签上, 使用 useGeneratedKeys="true"keyProperty="userId"
  2. 在 insert 表内部, 使用 selectKey标签 , 里面使用select last_insert_id()查询生成的 ID 返回

15- 当实体类中的属性名和表中的字段名不一样 ,怎么办

第 1 种: 通过在查询的 SQL 语句中定义字段名的别名,让字段名的别名和实体类的属性名一致。

第 2 种: 通过 ResultMap 来映射字段名和实体类属性名

16- Mybatis 如何实现多表查询

Mybatis 是新多表查询的方式也有二种 :

第一种是 : 编写多表关联查询的 SQL 语句 , 使用 ResultMap 建立结果集映射 , 在 ResultMap 中建立多表结果集映射的标签有associationcollection

<resultMap id="Account_User_Map" type="com.heima.entity.Account">
    <id property="id" column="id"></id>
    <result property="uid" column="uid"></result>
    <result property="money" column="money"></result>

    <association property="user">
        <id property="id" column="uid"></id>
        <result property="username" column="username"></result>
        <result property="birthday" column="birthday"></result>
        <result property="sex" column="sex"></result>
        <result property="address" column="address"></result>
    </association>

</resultMap>

<!--public Account findByIdWithUser(Integer id);-->
<select id="findByIdWithUser" resultMap="Account_User_Map">
    select  a.*,  username, birthday, sex, address  from account a , user u where a.UID = u.id and a.ID = #{id} ;
</select>

第二种是 : 将多表查询分解为多个单表查询, 使用 ResultMap 表的子标签associationcollection标签的select属性指定另外一条 SQL 的定义去执行, 然后执行结果会被自动封装

<resultMap id="Account_User_Map" type="com.heima.entity.Account" autoMapping="true">
    <id property="id" column="id"></id>

    <association property="user" select="com.heima.dao.UserDao.findById" column="uid" fetchType="lazy"></association>
</resultMap>

<!--public Account findByIdWithUser(Integer id);-->
<select id="findByIdWithUser" resultMap="Account_User_Map">
    select * from account where  id = #{id}
</select>

17-Mybatis 都有哪些动态 sql?能简述一下动 态 sql 的执行原理吗?

Mybatis 动态 sql 可以让我们在 Xml 映射文件内,以标签的形式编写动态 sql,完成逻辑判断和动态 拼接 sql 的功能,Mybatis 提供了 9 种动态 sql 标签 trim|where|set|foreach|if|choose|when|otherwise|bind。

其执行原理为,使用 OGNL 从 sql 参数对象中计算表达式的值,根据表达式的值动态拼接 sql,以此 来完成动态 sql 的功能。

18- Mybatis 是否支持延迟加载?

Mybatis 仅支持 association 关联对象和 collection 关联集合对象的延迟加载,association 指的就是 一对一,collection 指的就是一对多查询。在 Mybatis 配置文件中,可以配置是否启用延迟加载 lazyLoadingEnabled=true|false。

19- 如何使用 Mybatis 实现批量插入 ?

使用 foreach 标签 , 它可以在 SQL 语句中进行迭代一个集合。foreach 标签的属性主 要有 item,index,collection,open,separator,close。

  • collection : 代表要遍历的集合 ,
  • item   表示集合中每一个元素进行迭代时的别名,随便起的变量名;
  • index   指定一个名字,用于表示在迭代过程中,每次迭代到的位置,不常用;
  • open   表示该语句以什么开始
  • separator 表示在每次进行迭代之间以什么符号作为分隔符
  • close   表示以什么结束

20- Mybatis 批量插入是否能够返回主键

可以, 返回的主键在传入集合的每个对象属性中封装的

21- Mybatis 的一级、二级缓存 ?

一级缓存: 基于 SqlSession 级别的缓存 , 默认开启

二级缓存 : 基于 SqlSessionFactory 的 NameSpace 级别缓存 , 默认没有开启, 需要手动开启

# 配置cacheEnabled为true
<settings>...
  <!-- 开启二级缓存 -->
  <setting name="cacheEnabled" value="true"/>
  ...
</settings>

# 在映射配置文件中配置cache相关配置
<cache eviction="FIFO" flushInterval="60000" readOnly="false" size="1024">
</cache>

标签:02,Spring,sql,SSM,bean,必会,Mybatis,注解,注入
From: https://www.cnblogs.com/NorthPoet/p/17399567.html

相关文章

  • 04-面试必会-Redis篇
    01-你们项目中哪里用到了Redis?在我们的项目中很多地方都用到了Redis,Redis在我们的项目中主要有三个作用:使用Redis做热点数据缓存/接口数据缓存使用Redis存储一些业务数据,例如:验证码,用户信息,用户行为数据,数据计算结果,排行榜数据等使用Redis......
  • 06-面试必会-MQ篇
    RabbitMQ01-你们项目中哪里用到了RabbitMQ?我们项目中很多地方都使用了RabbitMQ,RabbitMQ是我们项目中服务通信的主要方式之一,我们项目中服务通信主要有二种方式实现:通过Feign实现服务调用通过MQ实现服务通信基本上除了查询请求之外,大部分的服务调用都采......
  • 05-面试必会-SpringBoot&SpringCloud
    01-讲一讲SpringBoot自动装配的原理1.在SpringBoot项目的启动引导类上都有一个注解@SpringBootApplication这个注解是一个复合注解,其中有三个注解构成,分别是@SpringBootConfiguration:是@Configuration的派生注解,标注当前类是一个SpringBoot的配置类@......
  • 02-数据类型/常量/变量/运算符
    1.数据类型1.1数据类型分类构造类型--用户自定义的数据类型存储负数使用有符号数字符型也分为有符号数和无符号数#include<stdio.h>intmain(){}1.2基本数据类型bool类型bool不是基本数据类型,使用的时候需要加入头文件#include<stdbool.h>#include<std......
  • 2023/5/14 遇到关于mongodb部署的问题
    之前使用关于mongodb5的版本中,linux系统中tar解压mongodb文件夹后的bin目录中mongod是启动mongo服务,而里面默认自带一个连接mongodb的shell脚本mongo而这几天使用mongodb6的版本中发现mongo脚本没有了,去网上查看发现是mongodb发行了一个新的shell脚本工具mongosh,这个需要自己安装......
  • 26 IIC(四)AT24C02 EEPROM
    1.AT24C02简介设备使用AT24C02芯片(EEPROM)1.1原理图1.2引脚描述1.3寻址AT24C02使用7bit表示设备地址,其中高四位固定为1010。结果原理图可知EEPROM的地址为0x501.4读写操作需要注意一点EEPROM在接受到一帧写数据后会进入一段时间(twr)的内部写周期。此时间段内不响应......
  • [GDOUCTF 2023]Check_Your_Luck
    得到一个c++的源文件:进VSCODE也行,devc++也行IDA也行:得到一个方程组,解开就行,大力推荐手搓(增加数学的能力到了)(我不用)典型的z3,上脚本:s=Solver()v,w,x,y,z=Ints('vwxyz')s.add(v*23+w*-32+x*98+y*55+z*90==333322)s.add(v*123+w*-322+x......
  • SMU Spring 2023 Contest Round 3(2023年湘潭大学新生赛)
    ProblemA.签到啦从大到小排序,累加大于行李w时输出下标即可intans;voidsolve(){cin>>n>>m;intans=0;vector<int>a(n);for(inti=0;i<n;i++){cin>>a[i];}sort(a.begin(),a.end());reverse(a.begin......
  • 2023 SMU RoboCom-CAIP 选拔赛
    A.小斧头  #include<map>#include<set>#include<cmath>#include<queue>#include<stack>#include<cstdio>#include<vector>#include<climits>#include<cstring>#include<cstdlib>......
  • [HUBUCTF 2022 新生赛]help
    题目告诉我们要走迷宫了嘛,那么主要就是找地图:查壳:64位,进IDA:创建地图?跟进去看看:看看num里装了啥:emm挺长的,有能力的小伙伴可以手搓一个地图,反正我没手搓出来QWQ再看看判断,说是走54步,且check满足,那么先动调拿到地图吧,上步骤:在CreateMap()的左边双击,设置断点:随便......