| /* |
| * Copyright (c) 2012, 2020 Oracle and/or its affiliates. All rights reserved. |
| * |
| * This program and the accompanying materials are made available under the |
| * terms of the Eclipse Public License v. 2.0 which is available at |
| * http://www.eclipse.org/legal/epl-2.0, |
| * or the Eclipse Distribution License v. 1.0 which is available at |
| * http://www.eclipse.org/org/documents/edl-v10.php. |
| * |
| * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause |
| */ |
| |
| // Contributors: |
| // 12/07/2012-2.5 Guy Pelletier |
| // - 389090: JPA 2.1 DDL Generation Support (foreign key metadata support)) |
| // 02/20/2013-2.5 Guy Pelletier |
| // - 389090: JPA 2.1 DDL Generation Support (foreign key metadata support) |
| // 04/12/2013-2.5 Guy Pelletier |
| // - 405640: JPA 2.1 schema generation drop operation fails to include dropping defaulted fk constraints. |
| package org.eclipse.persistence.testing.models.jpa21.advanced.ddl; |
| |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| import java.util.List; |
| import java.util.Map; |
| |
| import jakarta.persistence.CollectionTable; |
| import jakarta.persistence.Column; |
| import jakarta.persistence.Convert; |
| import jakarta.persistence.Converts; |
| import jakarta.persistence.ElementCollection; |
| import jakarta.persistence.Embedded; |
| import jakarta.persistence.Entity; |
| import jakarta.persistence.ForeignKey; |
| import jakarta.persistence.GeneratedValue; |
| import jakarta.persistence.Id; |
| import jakarta.persistence.Inheritance; |
| import jakarta.persistence.JoinColumn; |
| import jakarta.persistence.JoinTable; |
| import jakarta.persistence.ManyToMany; |
| import jakarta.persistence.MapKeyColumn; |
| import jakarta.persistence.MapKeyJoinColumn; |
| import jakarta.persistence.OneToMany; |
| import jakarta.persistence.Table; |
| |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.AccomplishmentConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.AgeConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.DateConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.DistanceConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.GenderConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.HealthConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.LevelConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.RunningStatusConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.TimeConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.enums.Gender; |
| |
| import static jakarta.persistence.InheritanceType.JOINED; |
| |
| @Entity |
| @Inheritance(strategy=JOINED) |
| @Table(name="JPA21_DDL_RUNNER") |
| @Converts({ |
| @Convert(attributeName = "accomplishments.key", converter = AccomplishmentConverter.class), |
| @Convert(attributeName = "accomplishments", converter = DateConverter.class), |
| @Convert(attributeName = "age", converter = AgeConverter.class) |
| }) |
| public class Runner extends Athlete { |
| @Id |
| @GeneratedValue |
| protected Integer id; |
| |
| @Convert(converter=GenderConverter.class) |
| protected Gender gender; |
| |
| @Embedded |
| @Converts({ |
| @Convert(attributeName = "level", converter = LevelConverter.class), |
| @Convert(attributeName = "health", converter = HealthConverter.class), |
| @Convert(attributeName = "status.runningStatus", converter = RunningStatusConverter.class) |
| }) |
| protected RunnerInfo info; |
| |
| @OneToMany(mappedBy="runner") |
| @MapKeyJoinColumn( |
| name="TAG_ID", |
| foreignKey=@ForeignKey( |
| name="Runner_ShoeTag_Foreign_Key", |
| foreignKeyDefinition="FOREIGN KEY (TAG_ID) REFERENCES JPA21_DDL_SHOE_TAG (ID)" |
| ) |
| ) |
| protected Map<ShoeTag, Shoe> shoes; |
| |
| @ManyToMany |
| @JoinTable( |
| name="JPA21_DDL_RUNNERS_RACES", |
| joinColumns=@JoinColumn( |
| name="RUNNER_ID", |
| referencedColumnName="ID" |
| ), |
| foreignKey=@ForeignKey( |
| name="Runners_Races_Foreign_Key", |
| foreignKeyDefinition="FOREIGN KEY (RUNNER_ID) REFERENCES JPA21_DDL_RUNNER (ID)" |
| ), |
| inverseJoinColumns=@JoinColumn( |
| name="RACE_ID", |
| referencedColumnName="ID" |
| ), |
| inverseForeignKey=@ForeignKey( |
| name="Runners_Races_Inverse_Foreign_Key", |
| foreignKeyDefinition="FOREIGN KEY (RACE_ID) REFERENCES JPA21_DDL_RACE (ID)" |
| ) |
| ) |
| protected List<Race> races; |
| |
| @ElementCollection |
| @Column(name="TIME") |
| @MapKeyColumn(name="DISTANCE") |
| @CollectionTable( |
| name="JPA21_DDL_RUNNER_PBS", |
| joinColumns=@JoinColumn(name="RUNNER_ID"), |
| foreignKey=@ForeignKey( |
| name="Runner_PBS_Foreign_Key", |
| foreignKeyDefinition="FOREIGN KEY (RUNNER_ID) REFERENCES JPA21_DDL_RUNNER (ID)" |
| ) |
| ) |
| @Converts({ |
| @Convert(attributeName="key", converter = DistanceConverter.class), |
| @Convert(converter = TimeConverter.class) |
| }) |
| protected Map<String, String> personalBests; |
| |
| @ManyToMany |
| @JoinTable( |
| name="JPA21_DDL_RUNNERS_COACHES", |
| joinColumns=@JoinColumn( |
| name="RUNNER_ID", |
| referencedColumnName="ID" |
| ), |
| inverseJoinColumns=@JoinColumn( |
| name="COACH_ID", |
| referencedColumnName="ID" |
| ) |
| ) |
| protected List<Coach> coaches; |
| |
| public Runner() { |
| races = new ArrayList<Race>(); |
| coaches = new ArrayList<Coach>(); |
| personalBests = new HashMap<String, String>(); |
| } |
| |
| public void addPersonalBest(String distance, String time) { |
| personalBests.put(distance, time); |
| } |
| |
| public void addCoach(Coach coach) { |
| coaches.add(coach); |
| } |
| |
| public void addRace(Race race) { |
| races.add(race); |
| } |
| |
| public List<Coach> getCoaches() { |
| return coaches; |
| } |
| |
| public Gender getGender() { |
| return gender; |
| } |
| |
| public Integer getId() { |
| return id; |
| } |
| |
| public RunnerInfo getInfo() { |
| return info; |
| } |
| |
| public Map<String, String> getPersonalBests() { |
| return personalBests; |
| } |
| |
| public List<Race> getRaces() { |
| return races; |
| } |
| |
| public Map<ShoeTag, Shoe> getShoes() { |
| return shoes; |
| } |
| |
| public boolean isFemale() { |
| return gender.equals(Gender.Female); |
| } |
| |
| public boolean isMale() { |
| return gender.equals(Gender.Male); |
| } |
| |
| public void setCoaches(List<Coach> coaches) { |
| this.coaches = coaches; |
| } |
| |
| public void setGender(Gender gender) { |
| this.gender = gender; |
| } |
| |
| public void setInfo(RunnerInfo info) { |
| this.info = info; |
| } |
| |
| public void setIsFemale() { |
| this.gender = Gender.Female; |
| } |
| |
| public void setIsMale() { |
| this.gender = Gender.Male; |
| } |
| |
| public void setPersonalBests(Map<String, String> personalBests) { |
| this.personalBests = personalBests; |
| } |
| |
| public void setRaces(List<Race> races) { |
| this.races = races; |
| } |
| |
| public void setShoes(Map<ShoeTag, Shoe> shoes) { |
| this.shoes = shoes; |
| } |
| } |