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

Исключить создание определенной таблицы с помощью спящего режима?

У меня есть @Entity, который сопоставляется с представлением, вот как это выглядит

import org.hibernate.annotations.Immutable;
import javax.persistence.*;

@Table(name = "user_earning")
@Entity
@Immutable
public class UserFlightEarning {
    @Id public Long userId;
    public Long flightId;
    @Column(name = "flight_seq") public Long flightSequence;
}

Это отлично работает, я могу получить записи из представления с помощью dao. Однако я заметил в журналах, что Hibernate на самом деле пытается создать таблицу, но терпит неудачу, потому что она уже существует.

2015-11-12 21:56:34.841 ОШИБКА 4204 --- [ost-startStop-1] org.hibernate.tool.hbm2ddl.SchemaExport: HHH000389: Неудачно: создать таблицу user_profile (user_id bigint не null, avg_airtime integer, avg_fuel_points integer , целое число avg_miles, адрес электронной почты varchar(255), имя varchar(255), целое число_рейсов, целое число_дальних_перелетов, varchar_фамилии(255), целое число длиннейших_перелетов, varchar_самого_посещенного_города(255), целое_конец_уровня, целое_начало_уровня, первичный ключ (user_id)) 2015 -11-12 21:56:34.841 ОШИБКА 4204 --- [ost-startStop-1] org.hibernate.tool.hbm2ddl.SchemaExport: таблица «user_profile» уже существует

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


  • Насколько я знаю, спящий режим не поддерживает это. 12.11.2015
  • См. ответ здесь: stackoverflow.com/questions/438146/ вы, вероятно, хотите использовать только обновление, а не создавать схему каждый раз 12.11.2015
  • Спасибо за комментарии, ребята. @Zilvinas Я надеялся заставить Spring игнорировать эти объекты, когда у меня есть create-drop. 12.11.2015
  • В этом сообщении блога SchemaFilter используется для этого medium.com /@horiaconstantin/ 14.08.2019

Ответы:


1

Аннотация @Subselect — единственная аннотация в Hibernate, которая предотвращает создание соответствующей таблицы для @Entity:

@Entity
@Subselect("select * from user_earning")
public class UserFlightEarning {

    @Id 
    public Long userId;

    public Long flightId;

    @Column(name = "flight_seq") 
    public Long flightSequence;
}
13.11.2015
  • Спасибо за информацию. Должен ли я указывать параметры, которые я хочу использовать в своих запросах, в предложении @Subselect query WHERE? или дао будет достаточно? Я не совсем уверен, когда будет использоваться оператор внутри аннотации подвыборки. 14.11.2015
  • Достаточно DAO, особенно если вы хотите создавать разные запросы для представления. Подвыборка — это замена таблицы: SELECT ... FROM table заменяется на SELECT ... FROM (select * from user_earning) 14.11.2015
  • Очень полезно! Жаль, что нет JPA-эквивалента аннотации @Subselect. :( 26.02.2017
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге 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 , и использованием..

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