/*******************************************************************************
* Copyright (c) 2011, 2015 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:
* 03/24/2011-2.3 Guy Pelletier
* - 337323: Multi-tenant with shared schema support (part 1
* 04/05/2011-2.3 Guy Pelletier
* - 337323: Multi-tenant with shared schema support (part 3)
* 06/1/2011-2.3 Guy Pelletier
* - 337323: Multi-tenant with shared schema support (part 9)
* 06/30/2011-2.3.1 Guy Pelletier
* - 341940: Add disable/enable allowing native queries
* 11/10/2011-2.4 Guy Pelletier
* - 357474: Address primaryKey option from tenant discriminator column
******************************************************************************/
package org.eclipse.persistence.testing.models.jpa.advanced.multitenant;
import java.util.Collection;
import java.util.Vector;
import java.io.Serializable;
import javax.persistence.Basic;
import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.NamedNativeQuery;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.PrimaryKeyJoinColumn;
import javax.persistence.SecondaryTable;
import javax.persistence.Table;
import javax.persistence.Transient;
import org.eclipse.persistence.annotations.TenantDiscriminatorColumn;
import org.eclipse.persistence.annotations.Multitenant;
import org.eclipse.persistence.annotations.TenantDiscriminatorColumns;
import static javax.persistence.CascadeType.ALL;
@Entity
@Table(name="JPA_MAFIA_FAMILY")
@SecondaryTable(
name="JPA_FAMILY_REVENUE",
pkJoinColumns={@PrimaryKeyJoinColumn(name="FAMILY_ID", referencedColumnName="ID")}
)
@Multitenant
@TenantDiscriminatorColumn(name="TENANT_ID", contextProperty="tenant.id", primaryKey=true)
@NamedQueries({
@NamedQuery(
name="findAllMafiaFamilies",
query="SELECT s from MafiaFamily s"),
@NamedQuery(
name="DeleteAllMafiaFamilies",
query="DELETE FROM MafiaFamily m")
})
@NamedNativeQuery(
name="findSQLMafiaFamilies",
query="SELECT * FROM JPA_MAFIA_FAMILY")
public class MafiaFamily implements Serializable {
private int id;
private String name;
private Collection<Mafioso> mafiosos;
private Collection<String> tags;
private Double revenue;
public MafiaFamily() {
this.tags = new Vector<String>();
this.mafiosos = new Vector<Mafioso>();
}
public void addMafioso(Mafioso mafioso) {
mafiosos.add(mafioso);
mafioso.setFamily(this);
}
public void addTag(String tag) {
tags.add(tag);
}
@Id
@GeneratedValue
@Column(name="ID")
public int getId() {
return id;
}
@OneToMany(cascade=ALL, mappedBy="family")
public Collection<Mafioso> getMafiosos() {
return mafiosos;
}
@Basic
public String getName() {
return name;
}
@ElementCollection
@CollectionTable(
name="JPA_FAMILY_TAGS",
joinColumns={
@JoinColumn(name="FAMILY_ID", referencedColumnName="ID")
})
@Column(name="TAG")
public Collection<String> getTags() {
return tags;
}
@Basic
@Column(name="REVENUE", table="JPA_FAMILY_REVENUE")
public Double getRevenue() {
return revenue;
}
public void setId(int id) {
this.id = id;
}
public void setMafiosos(Collection<Mafioso> mafiosos) {
this.mafiosos = mafiosos;
}
public void setName(String name) {
this.name = name;
}
public void setRevenue(Double revenue) {
this.revenue = revenue;
}
public void setTags(Collection<String> tags) {
this.tags = tags;
}
public String toString() {
return "MafiaFamily[" + getId() + "] : " + name;
}
}