springmvc+spring+mybatis常用注解

@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后变为了立即加载渴望
 

猜你喜欢

转载自blog.csdn.net/qq_41558854/article/details/83445500
今日推荐