Я использую QueryDSL с Spring Data JPA в своем Java-проекте и сгенерировал файлы с помощью плагина QueryDSL maven для использования сгенерированных им классов модели QueryDSL. Это отлично работает, когда я использую его для вложенных объектов одного уровня, однако, если я пытаюсь получить доступ к объектам доступа второго уровня, он дает исключение NullPointerException, сохраняющее объект модели второго уровня не инициализируется.
Буду признателен за некоторую помощь.
Я получаю исключение NullPointerException в 3-й строке qmachine.vendor is null.
QTransaction qtransaction = QTransaction.transaction;
QMachine qmachine = qtransaction.machine;
BooleanExpression vendorexp = qmachine.vendor.vendor.eq(machineType);
Мои классы сопоставления приведены ниже: Транзакция
@Entity
@Table(name = "dsdsd")
public class Transaction extends AbstractPersistable<Long> {
private static final long serialVersionUID = 1L;
@ManyToOne
@JoinColumn(name = "machine_id")
private Machine machine;
}
И класс Machine:
@Entity
@Table(name="machine")
public class Machine extends AbstractPersistable<Long> {
private static final long serialVersionUID = 1L;
@ManyToOne
@JoinColumn(name="vendor_id")
private Vendor vendor;
}
, а класс Vendor -
@Entity
@Table(name="vendors")
public class Vendor extends AbstractPersistable<Long> {
private static final long serialVersionUID = 1L;
@Column(name="vendor")
@Enumerated(EnumType.STRING)
private VendorType vendor;
}
Я намеренно опустил методы получения и установки.