Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 批量插入多对多关系_Java_Hibernate_Jpa_Many To Many - Fatal编程技术网

Java 批量插入多对多关系

Java 批量插入多对多关系,java,hibernate,jpa,many-to-many,Java,Hibernate,Jpa,Many To Many,我的实体定义如下: class Group { // some irrelevant fields @ManyToMany(targetEntity=User.class) private List<User> users; } class User { // some irrelevant fields @ManyToMany(targetEntity=Group.class) private List<Group&g

我的实体定义如下:

class Group {

    // some irrelevant fields

    @ManyToMany(targetEntity=User.class)
    private List<User> users;
}

class User {

    // some irrelevant fields

    @ManyToMany(targetEntity=Group.class)
    private List<Group> groups;
}
类组{
//一些不相关的领域
@ManyToMany(targetEntity=User.class)
私人名单用户;
}
类用户{
//一些不相关的领域
@ManyToMany(targetEntity=Group.class)
私人名单组;
}

在我的界面中,我试图提供一种方法,以一种批量输入形式将用户添加到组中。有没有一种方法可以允许插入新的多对多条目,而不必首先加载组中的整个用户集合?

使用
mappedBy
,其中一侧必须是相反的一侧。您只需要更新所有者端

因此,如果将
User
设为所有者,则只需将组添加到用户

如果这是不够的,那么考虑使用SQL.


另外,
targetEntity
与列表的泛型类型是冗余的。您不需要它。

不,JPQL无法做到这一点,尽管您没有定义“以某种批量输入形式”。基本上,您要么使用本机查询(即SQL查询),要么获取整个集合。有关详细信息,请参阅。

如果换个角度看,也会出现类似的问题。由于它是一个批量输入表单,因此可能有20多个用户可以轻松更新。它们都必须被查询,然后在添加组后被持久化。看起来我必须在这里直接使用SQL。