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中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...