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
和存在的解决方法。