В моем проекте я пытаюсь заменить существующие сущности сущностями из других библиотек.У меня возникла странная проблема со спецификациями, критериями построения и соединениями.Здесь у меня есть следующие классы
@Entity
@Table(
name = "company"
)
public class RoomEntity{
@Id
@Column(
name = "id"
)
@GeneratedValue(
generator = "seq-table",
strategy = GenerationType.TABLE
)
private Integer id;
@OneToMany(
mappedBy = "parentCompany",
fetch = FetchType.LAZY,
orphanRemoval = false
)
private Set<RoomHierarchyEntity> children;
2
@Entity
@Table(
name = "room_hierarchy"
)
public class RoomHierarchyEntity {
@Id
@Column(
name = "id"
)
@GeneratedValue(
generator = "seq-table",
strategy = GenerationType.TABLE
)
private Integer id;
@ManyToOne(
fetch = FetchType.LAZY,
optional = false
)
@JoinColumn(
name = "parent_id",
foreignKey = @ForeignKey(
name = "fk_Roomhierarchy_p_room"
)
)
private RoomEntity parentRoom;
@ManyToOne(
fetch = FetchType.LAZY,
optional = false
)
@JoinColumn(
name = "child_id",
foreignKey = @ForeignKey(
name = "fk_Roomhierarchy_c_room"
)
)
private RoomEntity childRoom;
@Column(
name = "distance",
nullable = false
)
private Integer distance;
3
public class ResourceEntity {
@Id
@Column(
name = "id"
)
@GeneratedValue(
generator = "seq-table",
strategy = GenerationType.TABLE
)
private Long id;
@Column(
name = "room_id",
nullable = false
)
@NotNull
private Integer RoomId;
)
Service1.java
findByCompanyAnd(ResEntity.class, roomId);
Service2.java
public static <T> Specifications<T> findByRoomAnd(Class<T> queryClass, Integer companyId,
) {
return findByCompany(queryClass, companyId));
}
SpecificationsUtil.Java
public static <T> Specifications<T> findByCompany(Class<T> queryClass, Integer companyId) {
return findByCompany(queryClass, companyId, COLUMNS.get(queryClass));
}
private static <T> Specifications<T> findByRoom(final Class<T> queryClass, final Integer RoomId,
final Set<String> columnNames) {
return Specifications.where(new Specification<T>() {
@Override
public Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
Join<RoomEntity, RoomHierarchyEntity> chRoot = root.join("room").join("children");
Subquery<Integer> sq = query.subquery(Integer.class);
Root<T> sqRoot = sq.from(queryClass);
Join<CompanyEntity, CompanyHierarchyEntity> sqChRoot = sqRoot.join("room").join("children");
sq.select(sqChRoot.<Integer>get("distance"));
...
}
});
}
Разница между старым ResEntity и новым ResEntity заключается в том, что старый имеет сущность RoomEntity в качестве объекта, в котором новый объект имеет RoomId.,Я получаю различные ошибки, когда я помещаю новый тип ResEntity.
Я получаю ошибку в
Join<RoomEntity, RoomHierarchyEntity> chRoot = root.join("room").join("children");
Unable to locate Attribute with the the given name [children] on this ManagedType
Как мне объединить входящую сущность (ResEntity) с RoomEntity и RoomHierarchyсущность?
Выше код является устаревшим, и я действительно не понимаю, что он делает.Я просто хочу присоединиться к этим столам, и я хочу управлять ими без неприятных вещей.