I have two BillingAddress and ShippingAddress objects mapped to TABLE ADDRESS with a TYPE column of discriminator.
@Entity
@Table(name = "address")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "TYPE",discriminatorType = DiscriminatorType.INTEGER)
@DiscriminatorValue(value = "1")
@NamedQueries({
@NamedQuery(name = "Shippingaddress.findAll", query = "SELECT s FROM Shippingaddress s")})
public class Shippingaddress implements Serializable{}
@Entity
@Table(name = "address")
@DiscriminatorValue(value = "2")
@NamedQueries({
@NamedQuery(name = "Billingaddress.findAll", query = "SELECT b FROM Billingaddress b")})
public class Billingaddress extends Shippingaddress implements Serializable {}
I can save / update two types of addresses successfully in a database with different TYPE values.
The problem I am facing is when I query the ADDRESS table as follows:
Session session=getCurrentSession();
Query query=session.createQuery("from Billingaddress where userId.userId=:userId");
query.setLong("userId", userId);
billingaddress=(Billingaddress)query.uniqueResult();
This works fine, but the ShippingAddress request throws a NonUniqueResult exception, i.e. I get both ShippingAddress and Billingaddress as a result. Please let me know what to do differently.
Session session=getCurrentSession();
Query query=session.createQuery("from Shippingaddress where userId.userId=:userId");
query.setLong("userId", userId);
shippingaddress=(Shippingaddress)query.uniqueResult();
source
share