blob: ca85e87d35c6638660a81f5f924e9b9a779ff85a [file] [log] [blame]
/*
* 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:
// 02/08/2012-2.4 Guy Pelletier
// - 350487: JPA 2.1 Specification defined support for Stored Procedure Calls
package org.eclipse.persistence.testing.models.jpa21.advanced;
import java.io.Serializable;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Vector;
import jakarta.persistence.Entity;
import jakarta.persistence.Id;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.MapKey;
import jakarta.persistence.NamedNativeQuery;
import jakarta.persistence.OneToMany;
import jakarta.persistence.OneToOne;
import jakarta.persistence.Table;
import jakarta.persistence.TableGenerator;
import static jakarta.persistence.CascadeType.PERSIST;
import static jakarta.persistence.GenerationType.TABLE;
@Entity
@Table(name = "JPA21_DEPT")
public class Department implements Serializable {
private Integer id;
private String name;
private Employee departmentHead;
private Collection<Employee> employees;
private Collection<Employee> managers;
public Department() {
this("");
}
public Department(String name) {
this.name = name;
this.managers = new Vector();
}
public void addManager(Employee employee) {
if (employee != null && managers != null && !managers.contains(employee)) {
this.managers.add(employee);
}
}
@OneToOne(optional=true)
@JoinColumn(name="DEPT_HEAD", nullable=true)
public Employee getDepartmentHead() {
return this.departmentHead;
}
@OneToMany(mappedBy = "department")
public Collection<Employee> getEmployees() {
return employees;
}
@Id
@GeneratedValue(strategy = TABLE, generator = "DEPARTMENT_TABLE_GENERATOR")
@TableGenerator(
name = "DEPARTMENT_TABLE_GENERATOR",
table = "CMP3_DEPARTMENT_SEQ",
pkColumnName = "SEQ_NAME",
valueColumnName = "SEQ_COUNT",
pkColumnValue = "DEPT_SEQ")
public Integer getId() {
return id;
}
@OneToMany(cascade = PERSIST)
public Collection<Employee> getManagers() {
return managers;
}
public String getName() {
return name;
}
public void setDepartmentHead(Employee employee) {
this.departmentHead = employee;
}
public void setEmployees(Collection<Employee> employees) {
this.employees = employees;
}
public void setId(Integer id) {
this.id = id;
}
public void setManagers(Collection<Employee> managers) {
this.managers = managers;
}
public void setName(String name) {
this.name = name;
}
}