HHH-9455 : Unnecessary select count query in some cases

(cherry picked from commit 552c1c06d5)
This commit is contained in:
Gail Badner 2014-10-20 16:35:00 -07:00
parent 52f2c3a002
commit 460e966214
2 changed files with 12 additions and 8 deletions

View File

@ -1703,8 +1703,7 @@ public abstract class AbstractCollectionPersister
public void processQueuedOps(PersistentCollection collection, Serializable key, SessionImplementor session) public void processQueuedOps(PersistentCollection collection, Serializable key, SessionImplementor session)
throws HibernateException { throws HibernateException {
if ( collection.hasQueuedOperations() ) { if ( collection.hasQueuedOperations() ) {
int nextIndex = getSize( key, session ); doProcessQueuedOps( collection, key, session );
doProcessQueuedOps( collection, key, nextIndex, session );
} }
} }

View File

@ -182,28 +182,33 @@ public class OneToManyPersister extends AbstractCollectionPersister {
public void recreate(PersistentCollection collection, Serializable id, SessionImplementor session) public void recreate(PersistentCollection collection, Serializable id, SessionImplementor session)
throws HibernateException { throws HibernateException {
super.recreate( collection, id, session ); super.recreate( collection, id, session );
writeIndex( collection, collection.entries( this ), id, 0, session ); writeIndex( collection, collection.entries( this ), id, true, session );
} }
@Override @Override
public void insertRows(PersistentCollection collection, Serializable id, SessionImplementor session) public void insertRows(PersistentCollection collection, Serializable id, SessionImplementor session)
throws HibernateException { throws HibernateException {
super.insertRows( collection, id, session ); super.insertRows( collection, id, session );
writeIndex( collection, collection.entries( this ), id, 0, session ); writeIndex( collection, collection.entries( this ), id, true, session );
} }
@Override @Override
protected void doProcessQueuedOps(PersistentCollection collection, Serializable id, SessionImplementor session) protected void doProcessQueuedOps(PersistentCollection collection, Serializable id, SessionImplementor session)
throws HibernateException { throws HibernateException {
writeIndex( collection, collection.queuedAdditionIterator(), id, getSize( id, session ), session ); writeIndex( collection, collection.queuedAdditionIterator(), id, false, session );
} }
private void writeIndex(PersistentCollection collection, Iterator entries, Serializable id, private void writeIndex(
int nextIndex, SessionImplementor session) { PersistentCollection collection,
Iterator entries,
Serializable id,
boolean resetIndex,
SessionImplementor session) {
// If one-to-many and inverse, still need to create the index. See HHH-5732. // If one-to-many and inverse, still need to create the index. See HHH-5732.
if ( isInverse && hasIndex && !indexContainsFormula ) { if ( isInverse && hasIndex && !indexContainsFormula ) {
try { try {
if ( entries.hasNext() ) { if ( entries.hasNext() ) {
int nextIndex = resetIndex ? 0 : getSize( id, session );
Expectation expectation = Expectations.appropriateExpectation( getUpdateCheckStyle() ); Expectation expectation = Expectations.appropriateExpectation( getUpdateCheckStyle() );
while ( entries.hasNext() ) { while ( entries.hasNext() ) {