- @Controller:注解在类上,表示这是一个控制层bean。
- @Service: 注解在类上,表示这是一个业务层bean。
- @Repository: 注解在类上,表示这是一个数据访问层bean。
- @Autowired:按类型注入,默认属性required= true;当不能确定 Spring 容器中一定拥有某个类的Bean 时, 可以在需要自动注入该类 Bean 的地方可以使用 @Autowired(required = false), 这等于告诉Spring:在找不到匹配Bean时也不抛出BeanCreationException 异常。
- @Scope:注解在类上,描述spring容器如何创建Bean实例。
- singleton: 表示在spring容器中的单例,通过spring容器获得该bean时总是返回唯一的实例
- prototype:表示每次获得bean都会生成一个新的对象
- request:表示在一次http请求内有效(只适用于web应用)
- session:表示在一个用户会话内有效(只适用于web应用)
- globalSession:表示在全局会话内有效(只适用于web应用)
在多数情况,我们只会使用singleton和prototype两种scope,如果未指定scope属性,默认为singleton。
-
@Value:注解在变量上,从配置文件(yml或properties文件)中读取。例如:@Value(“${message}”)
-
@ConfigurationProperties 从配置文件(yml或properties文件)中读取属性并赋值给实体类中对应的名字相同的属性。
-
@Bean: 注解在方法上,声明当前方法返回一个Bean。
-
@ComponentScan:注解在类上,会自动扫描指定包下的全部标有 @Component注解的类,并注册成bean,当然包括 @Component下的子注解@Service、@Repository、@Controller。
-
@Configuration:注解在类上,表示这是一个IOC容器,相当于spring的配置文件,java配置的方式。 IOC容器的配置类一般与 @Bean 注解配合使用,用 @Configuration 注解类等价与 XML 中配置 beans,用@Bean 注解方法等价于 XML 中配置 bean。
-
@RestController 是一个结合了 @ResponseBody 和 @Controller 的注解。
-
@Responsebody 注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中。
-
@PathVariable @RequestParam :两者的作用都是将request里的参数的值绑定到contorl里的方法参数里的,区别在于,URL写法不同。
- 使用@RequestParam时,URL是这样的:http://host:port/path?参数名=参数值
- 使用@PathVariable时,URL是这样的:http://host:port/path/参数值
-
@RequestMapping:和请求报文是做对应的
- value,指定请求的地址
- method 请求方法类型 这个不写的话,自适应:get或者post
- consumes 请求的提交内容类型
- produces 指定返回的内容类型 仅当request请求头中的(Accept)类型中包含该指定类型才返回
- params 指定request中必须包含某些参数值
- headers 指定request中必须包含指定的header值
-
也可以使用下面的注解:
- @GetMapping
- @PostMapping
- @PutMapping
- @DeleteMapping
JPA注解
-
@Entity
@Table(name=“”):注解在类上表明这是一个实体类。一般用于jpa这两个注解一般一块使用,但是如果表名和实体类名相同的话,@Table可以省略。 -
@Column:通过@Column注解设置,包含的设置如下:
- name:数据库表字段名
- unique:是否唯一
- nullable:是否可以为空
-
@Id:表示该属性为主键。
-
@Transient:表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性。即不会生成字段于数据表。
-
@JoinColumn(name=”loginId”):一对一:本表中指向另一个表的外键。一对多:另一个表指向本表的外键。
-
@OneToOne、@OneToMany、@ManyToOne:对应hibernate配置文件中的一对一,一对多,多对一。
-
@GeneratedValue 用于标注主键的生成策略,通过 strategy 属性指定。默认情况下,JPA 自动选择一个最适合底层数据库的主键生成策略:SqlServer 对应 identity,MySQL 对应 auto increment。 还有以下几种策略可以选择:
- IDENTITY:采用数据库 ID自增长的方式来自增主键字段,Oracle 不支持这种方式。
- AUTO: JPA自动选择合适的策略,是默认选项。
- SEQUENCE:通过序列产生主键,通过 @SequenceGenerator 注解指定序列名,MySql 不支持这种方式。
- TABLE:通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。
网友评论