| /******************************************************************************* |
| * Copyright (c) 2012, 2013 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: |
| * 10/25/2012-2.5 Guy Pelletier |
| * - 374688: JPA 2.1 Converter support |
| * 11/19/2012-2.5 Guy Pelletier |
| * - 389090: JPA 2.1 DDL Generation Support (foreign key metadata support) |
| * 11/28/2012-2.5 Guy Pelletier |
| * - 374688: JPA 2.1 Converter support |
| * 12/07/2012-2.5 Guy Pelletier |
| * - 389090: JPA 2.1 DDL Generation Support (foreign key metadata support) |
| * 07/16/2013-2.5.1 Guy Pelletier |
| * - 412384: Applying Converter for parameterized basic-type for joda-time's DateTime does not work |
| ******************************************************************************/ |
| package org.eclipse.persistence.testing.models.jpa21.advanced; |
| |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| import java.util.List; |
| import java.util.Map; |
| |
| import javax.persistence.Basic; |
| 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.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.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.TagConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.converters.TimeConverter; |
| import org.eclipse.persistence.testing.models.jpa21.advanced.enums.Gender; |
| |
| import static javax.persistence.InheritanceType.JOINED; |
| |
| @Entity |
| @Inheritance(strategy=JOINED) |
| @Table(name="JPA21_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; |
| |
| @Basic |
| protected List<RunnerTag> tags; |
| |
| @Basic |
| protected List<String> serials; |
| |
| @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") |
| protected Map<ShoeTag, Shoe> shoes; |
| |
| @ManyToMany |
| @JoinTable( |
| name="JPA21_RUNNERS_RACES", |
| joinColumns=@JoinColumn( |
| name="RUNNER_ID", |
| referencedColumnName="ID" |
| ), |
| inverseJoinColumns=@JoinColumn( |
| name="RACE_ID", |
| referencedColumnName="ID" |
| ) |
| ) |
| protected List<Race> races; |
| |
| @ElementCollection |
| @Column(name="TIME") |
| @MapKeyColumn(name="DISTANCE") |
| @CollectionTable( |
| name="JPA21_RUNNER_PBS", |
| joinColumns=@JoinColumn(name="RUNNER_ID") |
| ) |
| @Converts({ |
| @Convert(attributeName="key", converter = DistanceConverter.class), |
| @Convert(converter = TimeConverter.class) |
| }) |
| protected Map<String, String> personalBests; |
| |
| public Runner() { |
| races = new ArrayList<Race>(); |
| personalBests = new HashMap<String, String>(); |
| shoes = new HashMap<ShoeTag, Shoe>(); |
| tags = new ArrayList<RunnerTag>(); |
| } |
| |
| public void addPersonalBest(String distance, String time) { |
| personalBests.put(distance, time); |
| } |
| |
| public void addRace(Race race) { |
| races.add(race); |
| } |
| |
| public void addSerial(String serial) { |
| serials.add(serial); |
| } |
| |
| public void addTag(String tag) { |
| tags.add(new RunnerTag(tag)); |
| } |
| |
| 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 List<String> getSerials() { |
| return serials; |
| } |
| |
| public Map<ShoeTag, Shoe> getShoes() { |
| return shoes; |
| } |
| |
| public List<RunnerTag> getTags() { |
| return tags; |
| } |
| |
| 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 setSerials(List<String> serials) { |
| this.serials = serials; |
| } |
| |
| public void setShoes(Map<ShoeTag, Shoe> shoes) { |
| this.shoes = shoes; |
| } |
| |
| public void setTags(List<RunnerTag> tags) { |
| this.tags = tags; |
| } |
| } |