Arhn - архитектура программирования

Спящий режим: когда использовать аннотацию @Index

В моем сценарии у меня есть сценарий генерации схемы для создания таблиц и необходимых индексов. Мне интересно, есть ли необходимость определять аннотацию @Index в спящих объектах, если да, то почему?

Сценарий:

create table issues (id, project_id, .., status_id)

create index idx_issues_projid on issues (project_id)

Объект:

@Table(name="issues")
public class DBIssue {

..
  @ManyToOne(fetch = FetchType.EAGER)
  @JoinColumn(name = "PROJECT_ID")
  @Index(name="INDEX_TFW_ISSUE_PROJECT_ID")
  private DBProject project;
}

Конфигурация гибернации:

<property name="hibernate.hbm2ddl.auto">off</property>

25.09.2013

Ответы:


1

Я предполагаю, что вы спрашиваете об аннотации Hibernate @Index, которая по существу была импортирована в JPA 2.1. Вы должны использовать @Index везде, где в противном случае вы заранее указали бы реляционной базе данных индексировать столбец, в первую очередь в поле, где, как вы знаете, вы будете выполнять много поисков. В этом случае, например, вы, вероятно, захотите «часто выбирать DBIssue, принадлежащие конкретному DBProject, поэтому имеет смысл проиндексировать этот столбец в таблице, содержащей DBIssue.

25.09.2013
  • Я это понимаю, но если у меня уже есть индекс, созданный в базе данных по нужным столбцам. Есть ли какая-либо польза в настройке того же в спящем объекте? Если я опущу эту аннотацию, есть ли какие-либо недостатки? 25.09.2013
  • Эта аннотация сообщает Hibernate (или провайдеру JPA 2.1) о создании индекса при создании схемы. Нет явной необходимости включать его в свой код, но это хорошая документация, которая гарантирует, что если вам когда-нибудь понадобится повторно сгенерировать ваш DDL, индекс будет присоединен автоматически. 25.09.2013
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..