@Component和@Bean的区别是什么`

  1. 作用对象不同。@Component注解作用于类,而@Bean注解作用于方法。
    换句话说就是@Comeponent写在类上面,根据类名进行注入,而Bean注解在方法上 可以将方法的返回值注入到spring中。
  2. @Component 注解通常是通过类路径自动侦测以及自动装配到spring容器中,(我们可以通过ComponentScan注解定义扫描的路径) ,当然我们可以在spring的配置文件中自定义扫描路径(如下),Bean注解通常是在标有该注解的方法中定义产生这个bean,告诉Spring这是某个类的实例,当我需要用它的时候还给我。
<context:component-scan base-package="com.sofency.ssm.controller"></context:component-scan>

将一个类声明为Spring的bean的注解有哪些?`

我们一般使用@AutoWired注解去自动装配bean ,而想要一个可以用@AutoWired注解自动装配的bean 可以采用以下注解

  1. @Component注解 通用的注解, 可标注任意类的spring组件,如果一个bean不知道属于哪一层,就可以使用@Component进行注解标注
  2. @Repository 注解 对应持久层即Dao层 主要用于数据库的相关操作
  3. @Service 对应服务层 即Service 主要涉及一些复杂的逻辑 需要用到Dao层注入
  4. @Controller 对应springmvc的控制层,即controller层 主要用于接收用户的请求,并调用service层的方法返回数据给前端。

注 这些注解都可以使用@Component代替,那标记注解的意义在哪,就在于它可以将扫描的范围缩减,减少查询的时间。

spring的事务隔离级别`

在TransactionDefinition接口中定义了五个表示隔离级别的常量:

ISOLATION_DEFAULT:使用后端数据库默认的隔离级别,Mysql默认采用的REPEATABLE_READ隔离级别;Oracle默认采用的READ_COMMITTED隔离级别。

ISOLATION_READ_UNCOMMITTED:最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读。

ISOLATION_READ_COMMITTED:允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生

ISOLATION_REPEATABLE_READ:对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生。

ISOLATION_SERIALIZABLE:最高的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。但是这将严重影响程序的性能。通常情况下也不会用到该级别。

Spring事务中有哪几种事务传播行为?

在TransactionDefinition接口中定义了八个表示事务传播行为的常量。

支持当前事务的情况:

PROPAGATION_REQUIRED:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。

PROPAGATION_SUPPORTS: 如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。

PROPAGATION_MANDATORY: 如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。(mandatory:强制性)。

不支持当前事务的情况:

PROPAGATION_REQUIRES_NEW: 创建一个新的事务,如果当前存在事务,则把当前事务挂起。

PROPAGATION_NOT_SUPPORTED: 以非事务方式运行,如果当前存在事务,则把当前事务挂起。

PROPAGATION_NEVER: 以非事务方式运行,如果当前存在事务,则抛出异常。

其他情况:

PROPAGATION_NESTED: 如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于PROPAGATION_REQUIRED。