Читаем Изучаем Java EE 7 полностью

При использовании стратегии «таблица на конкретный класс» столбцы таблицы корневого класса дублируются в листовых таблицах. Они будут иметь одинаковые имена. Но что, если применять унаследованную базу данных, а столбцы будут обладать другими именами? JPA задействует аннотацию @AttributeOverride для переопределения отображения одного столбца и @AttributeOverrides, если речь идет о переопределении нескольких.

Чтобы переименовать столбцы ID, TITLE и DESCRIPTION в таблицах BOOK и CD, код сущности Item не потребуется изменять, однако придется задействовать аннотацию @AttributeOverride для сущностей Book (листинг 5.62) и CD (листинг 5.63).

Листинг 5.62. Book переопределяет некоторые столбцы, связанные с Item

@Entity

@AttributeOverrides({

··@AttributeOverride(name = "id", 

·····················column = @Column(name = "book_id")),

··@AttributeOverride(name = "title", 

·····················column = @Column(name = "book_title")),

··@AttributeOverride(name = "description", 

·····················column = @Column(name = "book_description"))

})

public class Book extends Item {

··private String isbn;

··private String publisher;

··private Integer nbOfPage;

··private Boolean illustrations;

··// Конструкторы, геттеры, сеттеры

}

Листинг 5.63. CD переопределяет некоторые столбцы, связанные с Item

@Entity

@AttributeOverrides({

··@AttributeOverride(name = "id", 

·····················column = @Column(name = "cd_id")),

··@AttributeOverride(name = "title", 

·····················column = @Column(name = "cd_title")),

··@AttributeOverride(name = "description", 

·····················column = @Column(name = "cd_description"))

})

public class CD extends Item {

··private String musicCompany;

··private Integer numberOfCDs;

··private Float totalDuration;

··private String genre;

··// Конструкторы, геттеры, сеттеры

}

Поскольку требуется переопределить несколько атрибутов, вам необходимо использовать аннотацию @AttributeOverrides, которая принимает массив аннотаций @AttributeOverride. После этого каждая аннотация указывает на атрибут сущности Item и переопределяет отображение столбца с помощью аннотации @Column. Таким образом, name = "title" ссылается на атрибут title сущности Item, а @Column(name = "cd_title") информирует поставщика постоянства о том, что title надлежит отобразить в столбец CD_TITLE. Результат показан на рис. 5.27.

Рис. 5.27. Таблицы BOOK и CD переопределяют столбцы таблицы ITEM

Примечание

Ранее в разделе «Встраиваемые объекты» этой главы вы видели, что встраиваемый объект может совместно использоваться несколькими сущностями (Address был встроен в Customer и Order). Поскольку встраиваемые объекты — это внутренняя часть владеющей сущности, в таблице каждой сущности также будут иметься дубликаты столбцов, связанных с этими объектами. Кроме того, @AttributeOverrides можно применять, если вам необходимо переопределить встраиваемые столбцы.

<p>Типы классов в иерархии наследования</p></span><span>

В примерах, приводившихся ранее для объяснения стратегий отображения, были задействованы только сущности. Item, как и Book и CD, является сущностью. Однако сущностям не всегда приходится наследовать от сущностей. В иерархии классов могут быть смешаны всевозможные разные классы: сущности, а также классы, которые не являются сущностями (или временные классы), абстрактные сущности и отображенные суперклассы. Наследование от этих классов разных типов будет влиять на отображение.

Абстрактная сущность
Перейти на страницу:

Похожие книги

C# 4.0: полное руководство
C# 4.0: полное руководство

В этом полном руководстве по C# 4.0 - языку программирования, разработанному специально для среды .NET, - детально рассмотрены все основные средства языка: типы данных, операторы, управляющие операторы, классы, интерфейсы, методы, делегаты, индексаторы, события, указатели, обобщения, коллекции, основные библиотеки классов, средства многопоточного программирования и директивы препроцессора. Подробно описаны новые возможности C#, в том числе PLINQ, библиотека TPL, динамический тип данных, а также именованные и необязательные аргументы. Это справочное пособие снабжено массой полезных советов авторитетного автора и сотнями примеров программ с комментариями, благодаря которым они становятся понятными любому читателю независимо от уровня его подготовки. Книга рассчитана на широкий круг читателей, интересующихся программированием на C#.Введите сюда краткую аннотацию

Герберт Шилдт

Программирование, программы, базы данных
97 этюдов для архитекторов программных систем
97 этюдов для архитекторов программных систем

Успешная карьера архитектора программного обеспечения требует хорошего владения как технической, так и деловой сторонами вопросов, связанных с проектированием архитектуры. В этой необычной книге ведущие архитекторы ПО со всего света обсуждают важные принципы разработки, выходящие далеко за пределы чисто технических вопросов.?Архитектор ПО выполняет роль посредника между командой разработчиков и бизнес-руководством компании, поэтому чтобы добиться успеха в этой профессии, необходимо не только овладеть различными технологиями, но и обеспечить работу над проектом в соответствии с бизнес-целями. В книге более 50 архитекторов рассказывают о том, что считают самым важным в своей работе, дают советы, как организовать общение с другими участниками проекта, как снизить сложность архитектуры, как оказывать поддержку разработчикам. Они щедро делятся множеством полезных идей и приемов, которые вынесли из своего многолетнего опыта. Авторы надеются, что книга станет источником вдохновения и руководством к действию для многих профессиональных программистов.

Билл де Ора , Майкл Хайгард , Нил Форд

Программирование, программы, базы данных / Базы данных / Программирование / Книги по IT