@Service用于标注业务层组件
@Controller用于标注控制层组件
@Repository用于标注数据访问组件,即DAO组件
@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
使用控制器注解,则对应到之前的配置文件生成:
<bean id =“”class =“”/>
@Autowired:采用类型的方式完成自动装配
@Resource:采用名称+类型的方式完成自动装配(比较保险)
@ResponseBody注解(应用于控制器)。这个注解是什么呢,就是当你引入了杰克逊这个罐包的时候,再使用这个注解,用用SpringMVC就可以自动将它所修饰的方法的返回值转换为JSON格式,从而不需要人为的去转换!这个注解加上那个罐子包,可以完美的将所有的Java的对象转换为JSON格式!
@NotEmpty(message =“用户名不能为空”)
private String username;
@NotEmpty(message =“密码不能为空”)
private String password;
private List <Role> roleList; //一个用户具有多个角色
下面配置用户 - 角色的多对多关系
@ManyToMany
@JoinTable(name =“t_user_role”,joinColumns = {@ JoinColumn(name =“user_id”)},inverseJoinColumns = {@ JoinColumn(name =“role_id”)})
public List <Role> getRoleList(){
return roleList ;
}
公共无效setRoleList(列表<角色>的的RoleList){
this.roleList =的的RoleList;
}
@短暂的
表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性。
如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认其注解为@Basic
(1)ManyToOne(多对一)单向:不产生中间表,但可以用@Joincolumn(name =“”)来指定生成外键的名字,外键在多的一方表中产生!
(2)OneToMany(一对多)单向:会产生中间表,此时可以用@onooMany @Joincolumn(name =“”)避免产生中间表,并且指定了外键的名字(别看@joincolumn在一中写着,但它存在在多的那个表中)
(3)OneToMany,ManyToOne双向(如个不在@OneToMany中加mappedy属性就会产生中间表,此时通常在@ManyToOne的注解下再添上注解@Joincolumn(name =“”)来指定外键的名字(说明:多的一方为关系维护端,关系维护端负责外键记录的更新,关系被维护端没有权利更新外键记录)!(@ OneToMany(mappedBy =“一对多”)中,多中一的属性“)出现mapby为被维护端|||默认为延迟加载)
用例:@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name =“child_id”)
private OrderChild orderChild;
@OneToMany(mappedBy =“orderChild”,fetch = FetchType.LAZY,cascade = {CascadeType.MERGE})
@ NotFound(action = NotFoundAction.IGNORE)//代表可以为空,允许为null
private List <OrderChildGoods> goodsList;
冬眠中@ManyToOne默认是立即加载,@一对多默认是懒加载
但是如果加上了@NotFound之后设置的取= FetchType.LAZY是不起作用的,也就是设置@NotFound后变为了立即加载渴望