0

テーブル klienci が同じテーブルに結合する関数を書きました。sqlDeveloper でステートメントを確認したところ、正しい値が返されましたが、ここでは、最初のテーブルからの値が 2 回あります (変数 klient1 と klient2 は同じ値です)。外部キーはありません。多分誰かが私が間違ったことを見ていますか?

public List<Klienci[]> getAllKlienci() {

    Session session = HibernateUtil.getSessionFactory().openSession();
    Query query = session.createSQLQuery("select k1.id, k1.nr_klienta,"
            + " k1.nr_klienta_niekod, k1.nazwa_klienta, k2.id,"
            + " k2.nr_klienta, k2.nr_klienta_niekod, k2.nazwa_klienta"
            + " from klienci k1 "
            + "left join klienci k2 on k1.nr_klienta_niekod = k2.nr_klienta");


    List<Object[]> klienci = query.list();
    // Transformacja w List<Klienci[]> 

    List<Klienci[]> returnList = new ArrayList<>();

    for (Object[] klient : klienci) {
        Klienci[] retunArray = new Klienci[2];

        Klienci klient1 = new Klienci();

        klient1.setId( ((BigDecimal)klient[0]).longValue() );
        klient1.setNrKlienta( ((BigDecimal)klient[1]).longValue() );
        klient1.setNrKlientaNiekod( ((BigDecimal)klient[2]).longValue() );
        klient1.setNazwaKlienta( (String) klient[3] );

        Klienci klient2 = new Klienci();

        klient2.setId( ((BigDecimal)klient[4]).longValue() );
        klient2.setNrKlienta( ((BigDecimal)klient[5]).longValue() );
        klient2.setNrKlientaNiekod( ((BigDecimal)klient[6]).longValue() );
        klient2.setNazwaKlienta( (String) klient[7] );

        retunArray[0] = klient1;
        retunArray[1] = klient2;

        returnList.add(retunArray);

    }

    return returnList;
}
4

0 に答える 0