Отображение XML-данных свойства загрузки в режиме гибернации - PullRequest
0 голосов
/ 26 августа 2011

Можно ли заставить Hibernate лениво загрузить свойство на объект?В проекте, который я унаследовал, есть несколько сгустков, которые загружаются по умолчанию.Я надеюсь изменить XML в качестве временного интервала, прежде чем мы преобразуем сопоставления в аннотации.

Ответы [ 2 ]

2 голосов
/ 26 августа 2011
0 голосов
/ 04 июля 2016

С Hibernate 5, это можно сделать следующим образом: .

Для начала вам нужно добавить следующий плагин Maven:

<plugin>
    <groupId>org.hibernate.orm.tooling</groupId>
    <artifactId>hibernate-enhance-maven-plugin</artifactId>
    <version>${hibernate.version}</version>
    <executions>
        <execution>
            <configuration>
                <enableLazyInitialization>true</enableLazyInitialization>
            </configuration>
            <goals>
                <goal>enhance</goal>
            </goals>
        </execution>
    </executions>
</plugin>

Затем вы можете просто аннотировать свойства вашей сущности с помощью @Basic(fetch = FetchType.LAZY):

@Entity(name = "Event")
@Table(name = "event")
public class Event extends BaseEntity {

    @Type(type = "jsonb")
    @Column(columnDefinition = "jsonb")
    @Basic(fetch = FetchType.LAZY)
    private Location location;

    public Location getLocation() {
        return location;
    }

    public void setLocation(Location location) {
        this.location = location;
    }
}

Когда вы выбираете объект:

Event event = entityManager.find(Event.class, 
    eventHolder.get().getId());

LOGGER.debug("Fetched event");
assertEquals("Cluj-Napoca", event.getLocation().getCity());

Hibernate собирается загрузить свойство lazy с помощью вторичного select:

SELECT e.id AS id1_0_0_
FROM   event e
WHERE  e.id = 1

-- Fetched event

SELECT e.location AS location2_0_
FROM   event e
WHERE  e.id = 1
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...