java – JPA如何在@OneToMany关系的列上添加唯一约束,例如在用户名上添加

前端之家收集整理的这篇文章主要介绍了java – JPA如何在@OneToMany关系的列上添加唯一约束,例如在用户名上添加前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个代表网站和类用户的类网站.站点可以有多个用户.
class Site {

    private int site_ID;

    @OneToMany // with a join table
    private List<User> users;
    // ...
}

class User {

    private int user_ID;

    private String name;

    private String lastname;

    private String username;

    private String password;

}

我想允许所有网站上存在相同的用户名,但只允许一个网站存在.

Site/User/username
1   /1   /username1
1   /2   /username2
2   /3   /username1

我怎样才能做到这一点?

解决方法

用户拥有站点参考:
@ManyToOne(optional=false)
private Site site;

现在将约束添加用户

@Table(uniqueConstraints = {
    @UniqueConstraint(columnNames = { "username","site" }))
} @Entity
public class User{
// etc
}

您还必须更改站点映射:

@OneToMany(mappedBy="site")
private List<User> users;

猜你在找的Java相关文章