Это первый раз, когда я разрабатываю приложение Java и сразу сталкиваюсь с проблемой. Теперь у меня есть запрос SQL, как показано ниже:JOIN 3 Entities in JPA
Select PD.* From product PD
join Stock SP on PD.id = SP.product_id
join storage SR on SR.id = SP.storage_id
join status ST on ST.storage_id = SR.id
where ST.id ='1qa7n234i'
Мои объекты:
public class Product extends MainEntity {
public Product(){}
public void setAtcKey(String pAtcKey) {
atcKey = pAtcKey;
}
}
public class StockPosition extends MainEntity {
public StockPosition(){}
@XmlIDREF
public Product getProduct() {
return product;
}
public void setProduct(Product pProduct) {
product = pProduct;
}
@XmlIDREF
public Storage getStorage() {
return storage;
}
public void setStorage(Storage pStorage) {
storage = pStorage;
}
}
public class Storage extends MainEntity {
public Storage(){}
@XmlTransient
public Station getStation() {
return station;
}
public void setStation(Station pStation) {
station = pStation;
}
}
public class Status extends MainEntity {
public Status(){}
}
Так что я преобразовать его в CriteriaQuery как:
CriteriaBuilder cb = getCriteriaBuilder();
CriteriaQuery<Product> query = cb.createQuery(Product.class);
Root<Product> product = query.from(Product.class);
Join<StockPosition, Product> sp = product.join(StockPosition_.product);
Но я получил сообщение об ошибке, как The method join(SingularAttribute<? super Product,Y>) in the type From<Product,Product> is not applicable for the arguments (SingularAttribute<StockPosition,Product>)
? Это сообщение очень странно для меня (потому что я новичок). Спасибо
вы имели в виду HQL запрос? – sanbhat
Я использую: 'javax.persistence.criteria.Join' –
Не могли бы вы объяснить больше и дать нам более подробную информацию. – Khalil