java - JPA 多对多关系创建两个连接表

标签 java mysql jpa orm eclipselink

我正在尝试在 UserFileObject 类之间创建多对多关系,假设用户可以访问许多文件对象,文件对象可以通过以下方式访问许多用户和一对多关系,因为一个用户可以拥有多个文件,但一个文件只能由一个用户拥有。这是我的代码:

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.TABLE)
    public int id;
    public String firstname;
    public String lastname;
    public String publicAttributes;
    public String privateAttributes;

    @ManyToOne
    private Department department;

    @OneToMany(mappedBy = "user")
    public List<Device> devices = new ArrayList<Device>();

    @OneToMany(mappedBy = "userCreator")
    public List <FileObject> fileOwned = new ArrayList <FileObject>();

    @ManyToMany
    @JoinTable(name="USER_FILE_ACCESS")
    public List<FileObject> fileHasAccess = new ArrayList<FileObject>();
}

@Entity
public class FileObject {

    @Id
    @GeneratedValue(strategy = GenerationType.TABLE)
    public int id;
    String checksum;

    @OneToMany(mappedBy = "fileObject")
    public List<Policy> policies = new ArrayList<Policy>();

    byte[] encryptedFileKey;

    byte[] iv;

    @ManyToOne
    public User userCreator;

    @ManyToMany
    public List<User> listUserAccessor = new ArrayList<User>();
}

理论上,它应该只创建一个连接表,即 USER_FILE_ACCESS,但是当我运行脚本时,它创建了两个连接表,我不确定为什么。

以下是 SQL 命令的摘录:

show tables;
+------------------+
| Tables_in_cpabe  |
+------------------+
| DEPARTMENT       |
| DEVICE           |
| FILEOBJECT       |
| FILEOBJECT_USER  |
| POLICY           |
| SEQUENCE         |
| USER             |
| USER_FILE_ACCESS |
+------------------+

show columns from FILEOBJECT_USER;
+---------------------+---------+------+-----+---------+-------+
| Field               | Type    | Null | Key | Default | Extra |
+---------------------+---------+------+-----+---------+-------+
| FileObject_ID       | int(11) | NO   | PRI | NULL    |       |
| listUserAccessor_ID | int(11) | NO   | PRI | NULL    |       |
+---------------------+---------+------+-----+---------+-------+

show columns from USER_FILE_ACCESS;
+------------------+---------+------+-----+---------+-------+
| Field            | Type    | Null | Key | Default | Extra |
+------------------+---------+------+-----+---------+-------+
| User_ID          | int(11) | NO   | PRI | NULL    |       |
| fileHasAccess_ID | int(11) | NO   | PRI | NULL    |       |
+------------------+---------+------+-----+---------+-------+

如何让连接表只有一张表?

最佳答案

如果你想建立双向关系,那么:

@Entity
public class User {

@ManyToMany
@JoinTable(name="USER_FILE_ACCESS"
     joinColumns=@JoinColumn(name="user_id"),
        inverseJoinColumns=@JoinColumn(name="fileHasAccess_ID "))
public Set<FileObject> fileHasAccess;


@Entity
public class FileObject {

@ManyToMany
@JoinTable(name="USER_FILE_ACCESS"
         joinColumns=@JoinColumn(name="fileHasAccess_ID"),
            inverseJoinColumns=@JoinColumn(name="user_id"))
    public Set<User> listUserAccessor;

更新

尝试使用 SEt 而不是列表。

您还可以尝试另一个双向选项。因此,在引用侧或反向侧(非拥有侧),您将映射如下:

@ManyToMany(mappedBy = "fileHasAccess")
public Set<User> listUserAccessor;

另外,仔细检查列名..我可能放了一些与你在数据库中实际拥有的不同的东西。

关于java - JPA 多对多关系创建两个连接表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42069692/

相关文章:

java - 如何在 Spring Boot 中限制仅 5 个设备的登录?

java - 我在哪里可以找到所有 HQL 关键字的列表?

java - 从父类方法调用子类方法

java - 更改散点图中点的形状

Java - 响应式(Reactive)编程与事件监听器

mysql - sugarCRM 订单被忽略

mysql - 如何高效地从同一个表的两列中搜索单个id?

mysql - 查询 order by(两列的乘积)

java - Hibernate 级联删除期间的 ConstraintViolationException

java util UUID 与 Hornetq UUID