HHH-5109 @OneToOne - too many joins
git-svn-id: https://svn.jboss.org/repos/hibernate/core/trunk@19308 1b8cb986-b30d-0410-93ca-fae66ebed9b2
This commit is contained in:
parent
96783f2a7a
commit
b912a95d54
|
@ -1563,7 +1563,8 @@ public final class AnnotationBinder {
|
|||
}
|
||||
}
|
||||
//MapsId means the columns belong to the pk => not null
|
||||
final boolean mandatory = !ann.optional() || forcePersist;
|
||||
//@PKJC must be constrained
|
||||
final boolean mandatory = !ann.optional() || forcePersist || trueOneToOne;
|
||||
bindOneToOne(
|
||||
getCascadeStrategy( ann.cascade(), hibernateCascade, ann.orphanRemoval(), forcePersist ),
|
||||
joinColumns,
|
||||
|
|
|
@ -3,6 +3,7 @@ package org.hibernate.test.annotations.onetoone;
|
|||
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.hibernate.EmptyInterceptor;
|
||||
import org.hibernate.Query;
|
||||
import org.hibernate.Session;
|
||||
import org.hibernate.Transaction;
|
||||
|
@ -174,8 +175,8 @@ public class OneToOneTest extends TestCase {
|
|||
party.partyId = "id";
|
||||
party.partyAffiliate = affiliate;
|
||||
affiliate.party = party;
|
||||
|
||||
s.persist( party );
|
||||
s.persist( affiliate );
|
||||
s.getTransaction().commit();
|
||||
|
||||
s.clear();
|
||||
|
@ -271,6 +272,41 @@ public class OneToOneTest extends TestCase {
|
|||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* HHH-5109 @OneToOne - too many joins
|
||||
* This test uses an interceptor to verify that correct number of joins
|
||||
* are generated.
|
||||
*/
|
||||
public void testPkOneToOneSelectStatementDoesNotGenerateExtraJoin() {
|
||||
|
||||
Session s = openSession(new JoinCounter(1));
|
||||
Transaction tx = s.beginTransaction();
|
||||
Owner owner = new Owner();
|
||||
OwnerAddress address = new OwnerAddress();
|
||||
owner.setAddress( address );
|
||||
address.setOwner( owner );
|
||||
s.persist( owner );
|
||||
s.flush();
|
||||
s.clear();
|
||||
|
||||
owner = ( Owner ) s.get( Owner.class, owner.getId() );
|
||||
assertNotNull( owner );
|
||||
assertNotNull( owner.getAddress() );
|
||||
assertEquals( owner.getId(), owner.getAddress().getId() );
|
||||
s.flush();
|
||||
s.clear();
|
||||
|
||||
address = ( OwnerAddress ) s.get( OwnerAddress.class, address.getId() );
|
||||
assertNotNull( address );
|
||||
assertNotNull( address.getOwner() );
|
||||
assertEquals( address.getId(), address.getOwner().getId() );
|
||||
|
||||
tx.rollback();
|
||||
s.close();
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @see org.hibernate.test.annotations.TestCase#getAnnotatedClasses()
|
||||
*/
|
||||
|
@ -299,3 +335,54 @@ public class OneToOneTest extends TestCase {
|
|||
return new String[] { "org/hibernate/test/annotations/onetoone/orm.xml" };
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Verifies that generated 'select' statement has desired number of joins
|
||||
* @author Sharath Reddy
|
||||
*
|
||||
*/
|
||||
class JoinCounter extends EmptyInterceptor {
|
||||
|
||||
private static final long serialVersionUID = -3689681272273261051L;
|
||||
|
||||
private int expectedNumberOfJoins = 0;
|
||||
|
||||
public JoinCounter(int val) {
|
||||
super();
|
||||
this.expectedNumberOfJoins = val;
|
||||
}
|
||||
|
||||
public String onPrepareStatement(String sql) {
|
||||
|
||||
int numberOfJoins = 0;
|
||||
if (sql.startsWith("select")) {
|
||||
numberOfJoins = count(sql, "join");
|
||||
TestCase.assertEquals(expectedNumberOfJoins, numberOfJoins);
|
||||
}
|
||||
|
||||
return sql;
|
||||
}
|
||||
|
||||
/**
|
||||
* Count the number of instances of substring within a string.
|
||||
*
|
||||
* @param string String to look for substring in.
|
||||
* @param substring Sub-string to look for.
|
||||
* @return Count of substrings in string.
|
||||
*/
|
||||
private int count(final String string, final String substring)
|
||||
{
|
||||
int count = 0;
|
||||
int idx = 0;
|
||||
|
||||
while ((idx = string.indexOf(substring, idx)) != -1)
|
||||
{
|
||||
idx++;
|
||||
count++;
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -18,7 +18,7 @@ public class OwnerAddress {
|
|||
@GenericGenerator(strategy = "foreign", name = "fk", parameters = @Parameter(name="property", value="owner"))
|
||||
private Integer id;
|
||||
|
||||
@OneToOne(mappedBy="address", optional = false)
|
||||
@OneToOne(mappedBy="address")
|
||||
private Owner owner;
|
||||
|
||||
public Integer getId() {
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
//$Id$
|
||||
package org.hibernate.test.annotations.onetoone;
|
||||
|
||||
import javax.persistence.CascadeType;
|
||||
import javax.persistence.Entity;
|
||||
import javax.persistence.Id;
|
||||
import javax.persistence.OneToOne;
|
||||
|
@ -14,7 +15,7 @@ public class Party {
|
|||
@Id
|
||||
String partyId;
|
||||
|
||||
@OneToOne
|
||||
@OneToOne(cascade=CascadeType.ALL)
|
||||
@PrimaryKeyJoinColumn
|
||||
PartyAffiliate partyAffiliate;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue