blob: 3e1c138a2140882beaff6b70c3b6b98049694360 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013, 2017 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 v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* 02/04/2013-2.5 Guy Pelletier
* - 389090: JPA 2.1 DDL Generation Support
******************************************************************************/
package org.eclipse.persistence.testing.models.jpa22.advanced.ddl.schema;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.Convert;
import javax.persistence.Converts;
import javax.persistence.ElementCollection;
import javax.persistence.Embedded;
import javax.persistence.Entity;
import javax.persistence.ForeignKey;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.MapKeyColumn;
import javax.persistence.MapKeyJoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.AccomplishmentConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.AgeConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.DateConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.DistanceConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.GenderConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.HealthConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.LevelConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.RunningStatusConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.converters.TimeConverter;
import org.eclipse.persistence.testing.models.jpa22.advanced.enums.Gender;
import static javax.persistence.InheritanceType.JOINED;
@Entity
@Inheritance(strategy=JOINED)
@Table(name="JPA22_DDL_RUNNER", schema="RUNNER")
@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
@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 JPA22_DDL_SHOE_TAG (ID)"
)
)
protected Map<ShoeTag, Shoe> shoes;
@ManyToMany
@JoinTable(
name="JPA22_DDL_RUNNERS_RACES",
schema="RUNNER",
joinColumns=@JoinColumn(
name="RUNNER_ID",
referencedColumnName="ID",
foreignKey=@ForeignKey(
name="Runners_Races_Foreign_Key",
foreignKeyDefinition="FOREIGN KEY (RUNNER_ID) REFERENCES JPA22_DDL_RUNNER (ID)"
)
),
inverseJoinColumns=@JoinColumn(
name="RACE_ID",
referencedColumnName="ID",
foreignKey=@ForeignKey(
name="Runners_Races_Inverse_Foreign_Key",
foreignKeyDefinition="FOREIGN KEY (RACE_ID) REFERENCES JPA22_DDL_RACE (ID)"
)
)
)
protected List<Race> races;
@ElementCollection
@Column(name="TIME")
@MapKeyColumn(name="DISTANCE")
@CollectionTable(
name="JPA22_DDL_RUNNER_PBS",
schema="RUNNER",
joinColumns=@JoinColumn(
name="RUNNER_ID",
foreignKey=@ForeignKey(
name="Runner_PBS_Foreign_Key",
foreignKeyDefinition="FOREIGN KEY (RUNNER_ID) REFERENCES JPA22_DDL_RUNNER (ID)"
))
)
@Convert(attributeName="key", converter = DistanceConverter.class)
@Convert(converter = TimeConverter.class)
protected Map<String, String> personalBests;
public Runner() {
races = new ArrayList<>();
personalBests = new HashMap<>();
}
public void addPersonalBest(String distance, String time) {
personalBests.put(distance, time);
}
public void addRace(Race race) {
races.add(race);
}
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 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;
}
}