blob: 4f0dee5506ca53e20b787aedd4306072698c8d81 [file] [log] [blame]
/*
* Copyright (c) 1998, 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:
// Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.testing.models.jpa.ddlgeneration;
import jakarta.persistence.Column;
import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import static jakarta.persistence.GenerationType.TABLE;
import jakarta.persistence.Id;
import jakarta.persistence.IdClass;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.JoinColumns;
import jakarta.persistence.ManyToOne;
import jakarta.persistence.OneToOne;
import jakarta.persistence.Table;
import jakarta.persistence.TableGenerator;
/**
* Composite key Entity.
*
* @author Wonseok Kim
*/
@Entity
@IdClass(CKeyEntityAPK.class)
@Table(name = "DDL_CKENTA")
@TableGenerator(
name = "CKEYENTITY_TABLE_GENERATOR",
table = "DDL_CKENT_SEQ",
pkColumnName = "SEQ_NAME",
valueColumnName = "SEQ_COUNT",
pkColumnValue = "CKENT_SEQ"
)
public class CKeyEntityA {
@Id
@GeneratedValue(strategy = TABLE, generator = "CKEYENTITY_TABLE_GENERATOR")
@Column(name = "SEQ")
private int seq;
@Id
@Column(name = "F_NAME", length=64)
private String firstName;
@Id
@Column(name = "L_NAME", length=64)
private String lastName;
@ManyToOne
@JoinColumns({
@JoinColumn(name="B_SEQ", referencedColumnName = "SEQ"),
@JoinColumn(name="B_CODE", referencedColumnName = "CODE")
})
private CKeyEntityB bs;
@OneToOne(mappedBy="a")
private CKeyEntityC c;
// Relationship using candidate(unique) keys
// For testing whether a generated FK constraint has reordered unique keys according to target table.
// CKeyEntityB has unique constraint ("UNQ2", "UNQ1").
@OneToOne
@JoinColumns({
@JoinColumn(name="B_UNQ1", referencedColumnName = "UNQ1"),
@JoinColumn(name="B_UNQ2", referencedColumnName = "UNQ2")
})
private CKeyEntityB uniqueB;
public CKeyEntityA() {
}
public CKeyEntityA(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
public int getSeq() {
return seq;
}
public String getFirstName() {
return firstName;
}
public String getLastName() {
return lastName;
}
public CKeyEntityAPK getKey() {
return new CKeyEntityAPK(seq, firstName, lastName);
}
public CKeyEntityB getBs() {
return bs;
}
public void setBs(CKeyEntityB bs) {
this.bs = bs;
}
public CKeyEntityC getC() {
return c;
}
public void setC(CKeyEntityC c) {
this.c = c;
}
public CKeyEntityB getUniqueB() {
return uniqueB;
}
public void setUniqueB(CKeyEntityB uniqueB) {
this.uniqueB = uniqueB;
}
}