package org.hibernate.examples.mapping.inheritance.subclass;
import lombok.Getter;
import lombok.Setter;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import org.hibernate.annotations.DynamicInsert;
import org.hibernate.annotations.DynamicUpdate;
import org.hibernate.examples.utils.HashTool;
import org.hibernate.examples.utils.ToStringHelper;
import javax.persistence.*;
/**
* org.hibernate.examples.mapping.inheritance.subclass.CreditCard
*
* @author 배성혁 sunghyouk.bae@gmail.com
* @since 2013. 11. 30. 오후 2:15
*/
@Entity(name = "Subclass_CreditCard")
@DiscriminatorValue(value = "CreditCard")
@org.hibernate.annotations.Cache(region = "example", usage = CacheConcurrencyStrategy.READ_WRITE)
// SecondaryTable은 1:1 join 을 나타냅니다.
@SecondaryTable(name = "Subclass_CreditCard_Card",
pkJoinColumns = @PrimaryKeyJoinColumn(name = "BillingId"))
@DynamicInsert
@DynamicUpdate
@Getter
@Setter
public class CreditCard extends AbstractBilling {
private String companyName;
@Column(table = "Subclass_CreditCard_Card", nullable = false)
private String number;
@Column(table = "Subclass_CreditCard_Card", nullable = false)
private Integer expMonth;
@Column(table = "Subclass_CreditCard_Card", nullable = false)
private Integer expYear;
@Override
public int hashCode() {
return HashTool.compute(super.hashCode(), companyName, number);
}
@Override
public ToStringHelper buildStringHelper() {
return super.buildStringHelper()
.add("companyName", companyName)
.add("number", number)
.add("expMonth", expMonth)
.add("expYear", expYear);
}
private static final long serialVersionUID = 7982685426151968281L;
}