HHH-13969 query the page size on Sybase ASE

This commit is contained in:
Gavin King 2024-11-22 22:36:45 +01:00
parent b36641f60d
commit 11139c288a
2 changed files with 46 additions and 25 deletions

View File

@ -43,6 +43,13 @@ public interface DialectSpecificSettings {
*/ */
String SYBASE_ANSI_NULL = "hibernate.dialect.sybase.extended_string_size"; String SYBASE_ANSI_NULL = "hibernate.dialect.sybase.extended_string_size";
/**
* Specifies the maximum page size on Sybase.
*
* @settingDefault {@value org.hibernate.dialect.SybaseASEDialect#MAX_PAGE_SIZE}
*/
String SYBASE_PAGE_SIZE = "hibernate.dialect.sybase.page_size";
/** /**
* Specifies the bytes per character to use based on the database's configured * Specifies the bytes per character to use based on the database's configured
* <a href="https://dev.mysql.com/doc/refman/8.0/en/charset-charsets.html">charset</a>. * <a href="https://dev.mysql.com/doc/refman/8.0/en/charset-charsets.html">charset</a>.

View File

@ -29,7 +29,6 @@ import org.hibernate.exception.spi.SQLExceptionConversionDelegate;
import org.hibernate.exception.spi.TemplatedViolatedConstraintNameExtractor; import org.hibernate.exception.spi.TemplatedViolatedConstraintNameExtractor;
import org.hibernate.exception.spi.ViolatedConstraintNameExtractor; import org.hibernate.exception.spi.ViolatedConstraintNameExtractor;
import org.hibernate.internal.util.JdbcExceptionHelper; import org.hibernate.internal.util.JdbcExceptionHelper;
import org.hibernate.internal.util.config.ConfigurationHelper;
import org.hibernate.query.sqm.IntervalType; import org.hibernate.query.sqm.IntervalType;
import org.hibernate.query.common.TemporalUnit; import org.hibernate.query.common.TemporalUnit;
import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistry;
@ -49,7 +48,10 @@ import org.hibernate.type.descriptor.sql.spi.DdlTypeRegistry;
import jakarta.persistence.TemporalType; import jakarta.persistence.TemporalType;
import static org.hibernate.cfg.DialectSpecificSettings.SYBASE_ANSI_NULL; import static org.hibernate.cfg.DialectSpecificSettings.SYBASE_ANSI_NULL;
import static org.hibernate.cfg.DialectSpecificSettings.SYBASE_PAGE_SIZE;
import static org.hibernate.exception.spi.TemplatedViolatedConstraintNameExtractor.extractUsingTemplate; import static org.hibernate.exception.spi.TemplatedViolatedConstraintNameExtractor.extractUsingTemplate;
import static org.hibernate.internal.util.config.ConfigurationHelper.getBoolean;
import static org.hibernate.internal.util.config.ConfigurationHelper.getInt;
import static org.hibernate.type.SqlTypes.BOOLEAN; import static org.hibernate.type.SqlTypes.BOOLEAN;
import static org.hibernate.type.SqlTypes.DATE; import static org.hibernate.type.SqlTypes.DATE;
import static org.hibernate.type.SqlTypes.NCLOB; import static org.hibernate.type.SqlTypes.NCLOB;
@ -65,6 +67,8 @@ public class SybaseASEDialect extends SybaseDialect {
private static final DatabaseVersion MINIMUM_VERSION = DatabaseVersion.make( 16, 0 ); private static final DatabaseVersion MINIMUM_VERSION = DatabaseVersion.make( 16, 0 );
public static final int MAX_PAGE_SIZE = 16_384;
private final SizeStrategy sizeStrategy = new SizeStrategyImpl() { private final SizeStrategy sizeStrategy = new SizeStrategyImpl() {
@Override @Override
public Size resolveSize( public Size resolveSize(
@ -95,6 +99,7 @@ public class SybaseASEDialect extends SybaseDialect {
}; };
private final boolean ansiNull; private final boolean ansiNull;
private final int pageSize;
public SybaseASEDialect() { public SybaseASEDialect() {
this( MINIMUM_VERSION ); this( MINIMUM_VERSION );
@ -103,37 +108,29 @@ public class SybaseASEDialect extends SybaseDialect {
public SybaseASEDialect(DatabaseVersion version) { public SybaseASEDialect(DatabaseVersion version) {
super(version); super(version);
ansiNull = false; ansiNull = false;
pageSize = MAX_PAGE_SIZE;
} }
public SybaseASEDialect(DialectResolutionInfo info) { public SybaseASEDialect(DialectResolutionInfo info) {
super(info); super(info);
ansiNull = isAnsiNull( info ); ansiNull = isAnsiNull( info );
pageSize = pageSize( info );
} }
@Override @Override
protected String columnType(int sqlTypeCode) { protected String columnType(int sqlTypeCode) {
switch ( sqlTypeCode ) { return switch ( sqlTypeCode ) {
case BOOLEAN: { // On Sybase ASE, the 'bit' type cannot be null,
// On Sybase ASE, the 'bit' type cannot be null, // and cannot have indexes (while we don't use
// and cannot have indexes (while we don't use // tinyint to store signed bytes, we can use it
// tinyint to store signed bytes, we can use it // to store boolean values)
// to store boolean values) case BOOLEAN -> "tinyint";
return "tinyint"; case DATE -> "date";
} case TIME -> "time";
case DATE: { // Sybase uses `unitext` instead of the T-SQL `ntext` type name
return "date"; case NCLOB -> "unitext";
} default -> super.columnType( sqlTypeCode );
case TIME: { };
return "time";
}
case NCLOB: {
// Sybase uses `unitext` instead of the T-SQL `ntext` type name
return "unitext";
}
default: {
return super.columnType( sqlTypeCode );
}
}
} }
@Override @Override
@ -175,7 +172,7 @@ public class SybaseASEDialect extends SybaseDialect {
// not the individual column length -- anyway, the // not the individual column length -- anyway, the
// largest possible page size is 16k, so that's a // largest possible page size is 16k, so that's a
// hard upper limit // hard upper limit
return 16_384; return pageSize;
} }
@Override @Override
@ -220,7 +217,24 @@ public class SybaseASEDialect extends SybaseDialect {
} }
} }
// default to the dialect-specific configuration setting // default to the dialect-specific configuration setting
return ConfigurationHelper.getBoolean( SYBASE_ANSI_NULL, info.getConfigurationValues(), false ); return getBoolean( SYBASE_ANSI_NULL, info.getConfigurationValues(), false );
}
private int pageSize(DialectResolutionInfo info) {
final DatabaseMetaData databaseMetaData = info.getDatabaseMetadata();
if ( databaseMetaData != null ) {
try (java.sql.Statement s = databaseMetaData.getConnection().createStatement() ) {
final ResultSet rs = s.executeQuery( "SELECT @@maxpagesize" );
if ( rs.next() ) {
return rs.getInt( 1 );
}
}
catch (SQLException ex) {
// Ignore
}
}
// default to the dialect-specific configuration setting
return getInt( SYBASE_PAGE_SIZE, info.getConfigurationValues(), MAX_PAGE_SIZE );
} }
@Override @Override