/*******************************************************************************
* Copyright (c) 1998, 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:
* Oracle - initial API and implementation from Oracle TopLink
******************************************************************************/
package org.eclipse.persistence.testing.models.jpa.fieldaccess.relationships;
import java.util.HashSet;
import java.util.Collection;
import javax.persistence.*;
import static javax.persistence.GenerationType.*;
import static javax.persistence.CascadeType.*;
import org.eclipse.persistence.annotations.Cache;
@Entity(name="FieldAccessCustomer")
@Table(name="CMP3_FIELDACCESS_CUSTOMER")
@NamedQuery(
name="findAllCustomersFieldAccess",
query="SELECT OBJECT(thecust) FROM FieldAccessCustomer thecust"
)
@NamedNativeQueries(value={
@NamedNativeQuery(name="findAllSQLCustomersFieldAccess",
query="select * from CMP3_FIELDACCESS_CUSTOMER"),
@NamedNativeQuery(name="insertCustomer1111SQLFieldAccess",
query="INSERT INTO CMP3_FIELDACCESS_CUSTOMER (CUST_ID, NAME, CITY, CUST_VERSION) VALUES (1111, NULL, NULL, 1)"),
@NamedNativeQuery(name="deleteCustomer1111SQLFieldAccess",
query="DELETE FROM CMP3_FIELDACCESS_CUSTOMER WHERE (CUST_ID=1111)")})
@Cache(shared=false)
public class Customer implements java.io.Serializable{
@Id
@GeneratedValue(strategy=TABLE, generator="FIELDACCESS_CUSTOMER_TABLE_GENERATOR")
@TableGenerator(
name="FIELDACCESS_CUSTOMER_TABLE_GENERATOR",
table="CMP3_FIELDACCESS_CUSTOMER_SEQ",
pkColumnName="SEQ_NAME",
valueColumnName="SEQ_COUNT",
pkColumnValue="CUST_SEQ"
)
@Column(name="CUST_ID")
private Integer customerId;
@Version
@Column(name="CUST_VERSION")
private int version;
private String city;
private String name;
@OneToMany(cascade=ALL, mappedBy="customer")
private Collection<Order> orders = new HashSet<Order>();
@ManyToMany
@JoinTable(name="CMP3_FIELDACCESS_CUST_CUST")
private Collection<Customer> controlledCustomers = new HashSet<Customer>();
public Customer() {}
public Integer getCustomerId() {
return customerId;
}
public void setCustomerId(Integer id) {
this.customerId = id;
}
public int getVersion() {
return version;
}
protected void setVersion(int version) {
this.version = version;
}
public String getCity() {
return city;
}
public void setCity(String aCity) {
this.city = aCity;
}
public String getName() {
return name;
}
public void setName(String aName) {
this.name = aName;
}
public Collection<Order> getOrders() {
return orders;
}
public void setOrders(Collection<Order> newValue) {
this.orders = newValue;
}
public void addOrder(Order anOrder) {
getOrders().add(anOrder);
anOrder.setCustomer(this);
}
public void removeOrder(Order anOrder) {
getOrders().remove(anOrder);
}
public Collection<Customer> getCCustomers() {
return controlledCustomers;
}
public void setCCustomers(Collection<Customer> controlledCustomers) {
this.controlledCustomers = controlledCustomers;
}
public void addCCustomer(Customer controlledCustomer) {
getCCustomers().add(controlledCustomer);
}
}