У меня есть SQL-запрос, который мне нужно реализовать, используя CriteriaBuilder
, так как Criteria
устарела
SELECT c.country_id,
c.NAME "country",
cy.NAME capital,
l.NAME "language",
s.NAME sports
FROM country c
LEFT JOIN city cy
ON c.city_id=cy.city_id
LEFT JOIN locale l
ON l.lang_id =c.lang_id
LEFT JOIN con_sports_detail csd
on csd.country_id=c.country_id
LEFT JOIN sports s
ON s.sport_id =csd.sports_id
WHERE c.country_id =1
Я пытался реализовать и ссылаться на многие посты, но я не могу понять аргумент, принятый методом join ().
public List<Country>findByCountryId()
{
Session session = HibernateUtil.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
CriteriaBuilder cb=session.getCriteriaBuilder();
CriteriaQuery<Country> cq = cb.createQuery(Country.class);
Root<Country> country = cq.from(Country.class);
Join<Country, City> item = country.join(); // Stucked here
return c.list();
String query="FROM Country c"
+ " LEFT JOIN city cy ";
session.getTransaction().commit();
} catch (Exception e) {
if (tx != null) {
tx.rollback();
}
e.printStackTrace();
} finally {
session.close();
}
Модель страны
package com.javarnd.cip.model;
import java.util.List;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.ManyToOne;
import javax.persistence.OneToOne;
import javax.persistence.Table;
@Entity
@Table(name = "Country")
public class Country {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name = "country_id")
private long countryId;
private String name;
@ManyToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "lang_id")
private Language locale;
@OneToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "city_id")
private City capital;
@ManyToMany(cascade = CascadeType.ALL)
@JoinTable(name = "CON_SPORTS_DETAIL", joinColumns = @JoinColumn(name = "country_id"), inverseJoinColumns = @JoinColumn(name = "sports_id"))
private List<Sports> sportsList;
public long getCountryId() {
return countryId;
}
public void setCountryId(long countryId) {
this.countryId = countryId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Language getLocale() {
return locale;
}
public void setLocale(Language locale) {
this.locale = locale;
}
public City getCapital() {
return capital;
}
public void setCapital(City capital) {
this.capital = capital;
}
public List<Sports> getSportsList() {
return sportsList;
}
public void setSportsList(List<Sports> sportsList) {
this.sportsList = sportsList;
}
}
Пожалуйста, помогите мне, спасибо заранее
Кроме того, я также хочу узнать о лучших практиках, например, если у нас много объединений, то каков наилучший подход для получения данных HQL
или CriteriaBuilder