Skip to content

Commit ebcbeba

Browse files
committed
HHH-18642 Revert to Statement.RETURN_GENERATED_KEYS for identity only
1 parent 1adfaf3 commit ebcbeba

File tree

2 files changed

+25
-5
lines changed

2 files changed

+25
-5
lines changed

hibernate-community-dialects/src/main/java/org/hibernate/community/dialect/DB2LegacyDialect.java

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1075,6 +1075,19 @@ public IdentityColumnSupport getIdentityColumnSupport() {
10751075
return DB2IdentityColumnSupport.INSTANCE;
10761076
}
10771077

1078+
/**
1079+
* @return {@code true} because we can use {@code select ... from new table (insert .... )}
1080+
*/
1081+
@Override
1082+
public boolean supportsInsertReturning() {
1083+
return true;
1084+
}
1085+
1086+
@Override
1087+
public boolean supportsInsertReturningRowId() {
1088+
return false;
1089+
}
1090+
10781091
@Override
10791092
public boolean supportsValuesList() {
10801093
return true;

hibernate-core/src/main/java/org/hibernate/id/IdentityGenerator.java

Lines changed: 12 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -4,15 +4,17 @@
44
*/
55
package org.hibernate.id;
66

7+
import java.util.List;
8+
79
import org.hibernate.boot.spi.SessionFactoryOptions;
810
import org.hibernate.dialect.Dialect;
9-
import org.hibernate.engine.spi.SessionFactoryImplementor;
1011
import org.hibernate.generator.OnExecutionGenerator;
1112
import org.hibernate.id.insert.BasicSelectingDelegate;
1213
import org.hibernate.id.insert.GetGeneratedKeysDelegate;
1314
import org.hibernate.id.insert.InsertGeneratedIdentifierDelegate;
1415
import org.hibernate.id.insert.InsertReturningDelegate;
1516
import org.hibernate.id.insert.UniqueKeySelectingDelegate;
17+
import org.hibernate.metamodel.mapping.ModelPart;
1618
import org.hibernate.persister.entity.EntityPersister;
1719

1820
import static org.hibernate.generator.EventType.INSERT;
@@ -52,11 +54,16 @@ public String[] getReferencedColumnValues(Dialect dialect) {
5254

5355
@Override
5456
public InsertGeneratedIdentifierDelegate getGeneratedIdentifierDelegate(EntityPersister persister) {
55-
final SessionFactoryImplementor factory = persister.getFactory();
56-
final Dialect dialect = factory.getJdbcServices().getDialect();
57+
final Dialect dialect = persister.getFactory().getJdbcServices().getDialect();
58+
final SessionFactoryOptions sessionFactoryOptions = persister.getFactory().getSessionFactoryOptions();
59+
final List<? extends ModelPart> generatedProperties = persister.getGeneratedProperties( INSERT );
60+
if ( generatedProperties.size() == 1 && sessionFactoryOptions.isGetGeneratedKeysEnabled() ) {
61+
// Use Connection#prepareStatement(sql, Statement.RETURN_GENERATED_KEYS) when only retrieving identity
62+
assert generatedProperties.get( 0 ).isEntityIdentifierMapping();
63+
return dialect.getIdentityColumnSupport().buildGetGeneratedKeysDelegate( persister );
64+
}
5765
// Try to use generic delegates if the dialects supports them
58-
final SessionFactoryOptions sessionFactoryOptions = factory.getSessionFactoryOptions();
59-
if ( dialect.supportsInsertReturningGeneratedKeys() && sessionFactoryOptions.isGetGeneratedKeysEnabled() ) {
66+
else if ( dialect.supportsInsertReturningGeneratedKeys() && sessionFactoryOptions.isGetGeneratedKeysEnabled() ) {
6067
return new GetGeneratedKeysDelegate( persister, false, INSERT );
6168
}
6269
else if ( dialect.supportsInsertReturning() && noCustomSql( persister, INSERT ) ) {

0 commit comments

Comments
 (0)