Java 迭代以创建createCriteria。获取错误org.hibernate.QueryException:重复的关联路径

Java 迭代以创建createCriteria。获取错误org.hibernate.QueryException:重复的关联路径,java,hibernate,Java,Hibernate,我有一个图像表,每个图像都与一个画廊表有多对多的关系。我试图使用org.hibernate.Criteria返回链接到给定库列表的所有图像 我一直在尝试以下方法,其中我循环浏览库列表,并为每个库创建一个新的createCriteria(例如,每个所需库一个内部连接),这只适用于一个库。但是,当我尝试多个时,我得到一个org.hibernate.QueryException:重复的关联路径:库错误 ImagesDAOCustom.java public Images getRandomImages

我有一个图像表,每个图像都与一个画廊表有多对多的关系。我试图使用
org.hibernate.Criteria
返回链接到给定库列表的所有图像

我一直在尝试以下方法,其中我循环浏览库列表,并为每个库创建一个新的
createCriteria
(例如,每个所需库一个内部连接),这只适用于一个库。但是,当我尝试多个时,我得到一个
org.hibernate.QueryException:重复的关联路径:库
错误

ImagesDAOCustom.java

public Images getRandomImagesInGallerys(String[] galleryList) {             
        Session session = sessionFactory.getCurrentSession();
        Criteria criteria = session.createCriteria(Images.class, "image");
        // We want an image that is part of all galleries so we need to create
        // a join per gallery.
        for (String gallery: galleryList) {
            criteria.createCriteria("image.galleries", gallery);
            criteria.add(Restrictions.eq(gallery + ".name",gallery));
        }
        criteria.setProjection(Projections.distinct(Projections.property("id")));
        List<Integer> imageIdList = criteria.list();

        Images result;
        if (imageIdList.size() > 0) {
            int index = rand.nextInt(imageIdList.size());
            result = imagesDAO.findOne(imageIdList.get(index));
        } else {
            result = null;
        }
        return result;
    }
公共图像getRandomImagesInGallerys(字符串[]galleryList){ Session Session=sessionFactory.getCurrentSession(); 条件=session.createCriteria(Images.class,“image”); //我们想要一个图像,是所有画廊的一部分,所以我们需要创建 //每个画廊都有一个加入。 用于(字符串库:galleryList){ criteria.createCriteria(“image.gallers”,gallery); 添加(限制.eq(gallery+“.name”,gallery)); } 标准.setProjection(Projections.distinct(Projections.property(“id”))); List imageIdList=criteria.List(); 图像结果; 如果(imageIdList.size()>0){ int index=rand.nextInt(imageIdList.size()); 结果=imagesDAO.findOne(imageIdList.get(index)); }否则{ 结果=空; } 返回结果; } Images.java

public class Images  {

    @Id
    @GeneratedValue
    @Column(name="ugc_images_id")
    private int id;

    @JsonIgnore
    @JsonView(Views.Internal.class)
    @ManyToMany(fetch = FetchType.LAZY)
    @JoinTable(name="ugc_image_galleries", joinColumns={@JoinColumn(name="image_id")}, inverseJoinColumns={@JoinColumn(name="gallery_id")})
    private Set<Galleries> galleries = new HashSet<>();

    ...
}
公共类图像{
@身份证
@生成值
@列(name=“ugc\U图像\U id”)
私有int-id;
@杰索尼奥雷
@JsonView(Views.Internal.class)
@ManyToMany(fetch=FetchType.LAZY)
@JoinTable(name=“ugc_image_galleries”,joinColumns={@JoinColumn(name=“image_id”)},inverseJoinColumns={@JoinColumn(name=“gallery_id”)})
私有集库=新HashSet();
...
}
Galleries.java

public class Galleries }

    @Id
    @GeneratedValue
    @Column(name="ugc_galleries_id")
    private int id;

    @JsonManagedReference
    @ManyToMany(mappedBy="galleries")    
    private Set<Images> images = new HashSet<>();

    @Column(name="name")
    private String name;

    ...

}
公共类库}
@身份证
@生成值
@列(name=“ugc\U画廊\U id”)
私有int-id;
@JsonManagedReference
@许多(mappedBy=“画廊”)
private Set images=new HashSet();
@列(name=“name”)
私有字符串名称;
...
}

我遇到了同样的问题,我搜索了好几个小时

以下是对我有效的方法:

public Images getRandomImagesInGallerys(String[] galleryList) {

    String query = "from Images ";
    boolean first = true;

    for(String string : galleryList) {
        if(first){
            query+="where '"+string+"' member of galleries ";
            first=false;
        } else {
            query+="or '"+string+"' member of galleries ";
        }
    }

    entityManager.createQuery(query, Images.class).getResultList();
}

希望它能帮助别人。

我也有同样的问题,我搜索了好几个小时

以下是对我有效的方法:

public Images getRandomImagesInGallerys(String[] galleryList) {

    String query = "from Images ";
    boolean first = true;

    for(String string : galleryList) {
        if(first){
            query+="where '"+string+"' member of galleries ";
            first=false;
        } else {
            query+="or '"+string+"' member of galleries ";
        }
    }

    entityManager.createQuery(query, Images.class).getResultList();
}
希望它能帮助别人。

查看使用
SqlRestriction
存在的解决方法。
查看使用
SqlRestriction
存在的解决方法。