Как я могу использовать построитель критериев для создания эквивалентного SQL - PullRequest
0 голосов
/ 07 марта 2019

У меня есть 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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...