Merge remote-tracking branch 'upstream/main' into wip/6.0
This commit is contained in:
commit
6ca0be6d99
|
@ -884,6 +884,10 @@ For cases where the `javax.persistence.schema-generation.scripts.action` value i
|
|||
`*javax.persistence.schema-generation.scripts.drop-target*`::
|
||||
For cases where the `javax.persistence.schema-generation.scripts.action` value indicates that schema dropping commands should be written to DDL script file, `javax.persistence.schema-generation.scripts.drop-target` specifies either a `java.io.Writer` configured for output of the DDL script or a string specifying the file URL for the DDL script.
|
||||
|
||||
`*hibernate.hbm2ddl.schema-generation.script.append*` (e.g. `true` (default value) or `false`)::
|
||||
For cases where the `javax.persistence.schema-generation.scripts.action` value indicates that schema commands should be written to DDL script file, `hibernate.hbm2ddl.schema-generation.script.append` specifies if schema commands should be appended to the end of the file rather than written at the beginning of the file.
|
||||
Values are `true` for appending schema commands to the end of the file, `false` for writing achema commands at the beginning of the file.
|
||||
|
||||
`*javax.persistence.hibernate.hbm2ddl.import_files*` (e.g. `import.sql` (default value))::
|
||||
Comma-separated names of the optional files containing SQL DML statements executed during the `SessionFactory` creation.
|
||||
File order matters, the statements of a given file are executed before the statements of the following one.
|
||||
|
|
|
@ -231,6 +231,10 @@ task copyBundleResources (type: Copy) {
|
|||
// we will end up a test JAR with bundle files that where variables are replaced
|
||||
processTestResources.finalizedBy copyBundleResources
|
||||
|
||||
sourcesJar {
|
||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||
}
|
||||
|
||||
task testJar(type: Jar, dependsOn: testClasses) {
|
||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||
archiveClassifier.set( 'test' )
|
||||
|
|
|
@ -1683,6 +1683,16 @@ public interface AvailableSettings extends org.hibernate.jpa.AvailableSettings {
|
|||
@SuppressWarnings("JavaDoc")
|
||||
String HBM2DDL_SCRIPTS_CREATE_TARGET = "javax.persistence.schema-generation.scripts.create-target";
|
||||
|
||||
/**
|
||||
* For cases where the {@value #HBM2DDL_SCRIPTS_ACTION} value indicates that schema commands should
|
||||
* be written to DDL script file, specifies if schema commands should be appended to the end of the file rather than written at the beginning of the file.
|
||||
*
|
||||
* Values are: {@code true} for appending schema commands to the end of the file, {@code false} for writing schema commands at the beginning.
|
||||
*
|
||||
* The default value is {@code true}
|
||||
*/
|
||||
String HBM2DDL_SCRIPTS_CREATE_APPEND = "hibernate.hbm2ddl.schema-generation.script.append";
|
||||
|
||||
/**
|
||||
* For cases where the {@value #HBM2DDL_SCRIPTS_ACTION} value indicates that schema drop commands should
|
||||
* be written to DDL script file, {@value #HBM2DDL_SCRIPTS_DROP_TARGET} specifies either a
|
||||
|
|
|
@ -136,6 +136,7 @@ public class SchemaExport {
|
|||
}
|
||||
}
|
||||
|
||||
boolean append = true;
|
||||
boolean haltOnError = false;
|
||||
boolean format = false;
|
||||
boolean manageNamespaces = false;
|
||||
|
@ -160,6 +161,18 @@ public class SchemaExport {
|
|||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* For generating a export script file, by default the content will be appended at the begin or end of the file.
|
||||
*
|
||||
* The sql will be written at the beginning of the file rather append to the end.
|
||||
*
|
||||
* @return this
|
||||
*/
|
||||
public SchemaExport setOverrideOutputFileContent() {
|
||||
append = false;
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Comma-separated list of resource names to use for database init commands on create.
|
||||
*
|
||||
|
@ -244,7 +257,12 @@ public class SchemaExport {
|
|||
|
||||
LOG.runningHbm2ddlSchemaExport();
|
||||
|
||||
final TargetDescriptor targetDescriptor = buildTargetDescriptor( targetTypes, outputFile, serviceRegistry );
|
||||
final TargetDescriptor targetDescriptor = buildTargetDescriptor(
|
||||
targetTypes,
|
||||
outputFile,
|
||||
append,
|
||||
serviceRegistry
|
||||
);
|
||||
|
||||
doExecution( action, needsJdbcConnection( targetTypes ), metadata, serviceRegistry, targetDescriptor );
|
||||
}
|
||||
|
@ -318,6 +336,14 @@ public class SchemaExport {
|
|||
EnumSet<TargetType> targetTypes,
|
||||
String outputFile,
|
||||
ServiceRegistry serviceRegistry) {
|
||||
return buildTargetDescriptor( targetTypes, outputFile, true, serviceRegistry );
|
||||
}
|
||||
|
||||
public static TargetDescriptor buildTargetDescriptor(
|
||||
EnumSet<TargetType> targetTypes,
|
||||
String outputFile,
|
||||
boolean append,
|
||||
ServiceRegistry serviceRegistry) {
|
||||
final ScriptTargetOutput scriptTarget;
|
||||
if ( targetTypes.contains( TargetType.SCRIPT ) ) {
|
||||
if ( outputFile == null ) {
|
||||
|
@ -326,7 +352,8 @@ public class SchemaExport {
|
|||
scriptTarget = Helper.interpretScriptTargetSetting(
|
||||
outputFile,
|
||||
serviceRegistry.getService( ClassLoaderService.class ),
|
||||
(String) serviceRegistry.getService( ConfigurationService.class ).getSettings().get( AvailableSettings.HBM2DDL_CHARSET_NAME )
|
||||
(String) serviceRegistry.getService( ConfigurationService.class ).getSettings().get( AvailableSettings.HBM2DDL_CHARSET_NAME ),
|
||||
append
|
||||
);
|
||||
}
|
||||
else {
|
||||
|
|
|
@ -56,6 +56,7 @@ public class SchemaUpdate {
|
|||
boolean haltOnError = false;
|
||||
|
||||
private String outputFile;
|
||||
private boolean append = true;
|
||||
private String delimiter;
|
||||
private boolean format;
|
||||
|
||||
|
@ -88,7 +89,7 @@ public class SchemaUpdate {
|
|||
exceptionHandler
|
||||
);
|
||||
|
||||
final TargetDescriptor targetDescriptor = SchemaExport.buildTargetDescriptor( targetTypes, outputFile, serviceRegistry );
|
||||
final TargetDescriptor targetDescriptor = SchemaExport.buildTargetDescriptor( targetTypes, outputFile, append, serviceRegistry );
|
||||
|
||||
try {
|
||||
tool.getSchemaMigrator( config ).doMigration( metadata, executionOptions, ContributableMatcher.ALL, targetDescriptor );
|
||||
|
@ -124,6 +125,18 @@ public class SchemaUpdate {
|
|||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* For generating a export script file, by default the content will be appended at the begin or end of the file.
|
||||
*
|
||||
* The sql will be written at the beginning of the file rather append to the end.
|
||||
*
|
||||
* @return this
|
||||
*/
|
||||
public SchemaUpdate setOverrideOutputFileContent() {
|
||||
append = false;
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the end of statement delimiter
|
||||
*
|
||||
|
|
|
@ -94,7 +94,8 @@ public class Helper {
|
|||
public static ScriptTargetOutput interpretScriptTargetSetting(
|
||||
Object scriptTargetSetting,
|
||||
ClassLoaderService classLoaderService,
|
||||
String charsetName ) {
|
||||
String charsetName,
|
||||
boolean append) {
|
||||
if ( scriptTargetSetting == null ) {
|
||||
return null;
|
||||
}
|
||||
|
@ -119,7 +120,7 @@ public class Helper {
|
|||
|
||||
// assume it is a File path
|
||||
final File file = new File( scriptTargetSettingString );
|
||||
return new ScriptTargetOutputToFile( file, charsetName );
|
||||
return new ScriptTargetOutputToFile( file, charsetName, append );
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -28,6 +28,7 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
|
||||
private final File file;
|
||||
private final String charsetName;
|
||||
private final boolean append;
|
||||
|
||||
private Writer writer;
|
||||
|
||||
|
@ -36,10 +37,24 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
*
|
||||
* @param file The file to read from
|
||||
* @param charsetName The charset name
|
||||
* @param append If true, then bytes will be written to the end of the file rather than the beginning
|
||||
*/
|
||||
public ScriptTargetOutputToFile(File file, String charsetName) {
|
||||
public ScriptTargetOutputToFile(File file, String charsetName, boolean append) {
|
||||
this.file = file;
|
||||
this.charsetName = charsetName;
|
||||
this.append = append;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a ScriptTargetOutputToFile instance,
|
||||
* the bytes will be written to the end of the file rather than the beginning
|
||||
*
|
||||
* @param file The file to read from
|
||||
* @param charsetName The charset name
|
||||
*
|
||||
*/
|
||||
public ScriptTargetOutputToFile(File file, String charsetName ) {
|
||||
this(file, charsetName, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -53,7 +68,7 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
@Override
|
||||
public void prepare() {
|
||||
super.prepare();
|
||||
this.writer = toFileWriter( this.file, this.charsetName );
|
||||
this.writer = toFileWriter( this.file, this.charsetName, append );
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -63,7 +78,7 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
writer.close();
|
||||
}
|
||||
catch (IOException e) {
|
||||
throw new SchemaManagementException( "Unable to close file writer : " + e.toString() );
|
||||
throw new SchemaManagementException( "Unable to close file writer : " + e );
|
||||
}
|
||||
finally {
|
||||
writer = null;
|
||||
|
@ -72,7 +87,7 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
}
|
||||
|
||||
@SuppressWarnings("ResultOfMethodCallIgnored")
|
||||
static Writer toFileWriter( File file, String charsetName ) {
|
||||
static Writer toFileWriter(File file, String charsetName, boolean append) {
|
||||
try {
|
||||
if ( ! file.exists() ) {
|
||||
// best effort, since this is very likely not allowed in EE environments
|
||||
|
@ -84,17 +99,17 @@ public class ScriptTargetOutputToFile extends AbstractScriptTargetOutput impleme
|
|||
}
|
||||
}
|
||||
catch (Exception e) {
|
||||
log.debug( "Exception calling File#createNewFile : " + e.toString() );
|
||||
log.debug( "Exception calling File#createNewFile : " + e );
|
||||
}
|
||||
try {
|
||||
return charsetName != null ?
|
||||
new OutputStreamWriter(
|
||||
new FileOutputStream( file, true ),
|
||||
new FileOutputStream( file, append ),
|
||||
charsetName
|
||||
) :
|
||||
new OutputStreamWriter( new FileOutputStream(
|
||||
file,
|
||||
true
|
||||
append
|
||||
) );
|
||||
}
|
||||
catch (IOException e) {
|
||||
|
|
|
@ -28,6 +28,7 @@ public class ScriptTargetOutputToUrl extends AbstractScriptTargetOutput implemen
|
|||
|
||||
private final URL url;
|
||||
private final String charsetName;
|
||||
private final boolean append;
|
||||
|
||||
private Writer writer;
|
||||
|
||||
|
@ -36,10 +37,23 @@ public class ScriptTargetOutputToUrl extends AbstractScriptTargetOutput implemen
|
|||
*
|
||||
* @param url The url to read from
|
||||
* @param charsetName The charset name
|
||||
* @param append If true, then bytes will be written to the end of the file rather than the beginning
|
||||
*/
|
||||
public ScriptTargetOutputToUrl(URL url, String charsetName) {
|
||||
public ScriptTargetOutputToUrl(URL url, String charsetName, boolean append) {
|
||||
this.url = url;
|
||||
this.charsetName = charsetName;
|
||||
this.append = append;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a ScriptTargetOutputToUrl instance
|
||||
* the bytes will be written to the end of the file rather than the beginning
|
||||
*
|
||||
* @param url The url to read from
|
||||
* @param charsetName The charset name
|
||||
*/
|
||||
public ScriptTargetOutputToUrl(URL url, String charsetName) {
|
||||
this( url, charsetName, true );
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -53,7 +67,7 @@ public class ScriptTargetOutputToUrl extends AbstractScriptTargetOutput implemen
|
|||
@Override
|
||||
public void prepare() {
|
||||
super.prepare();
|
||||
this.writer = toWriter( url, charsetName );
|
||||
this.writer = toWriter( url, charsetName, append );
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -62,17 +76,17 @@ public class ScriptTargetOutputToUrl extends AbstractScriptTargetOutput implemen
|
|||
writer().close();
|
||||
}
|
||||
catch (IOException e) {
|
||||
throw new SchemaManagementException( "Unable to close file writer : " + e.toString() );
|
||||
throw new SchemaManagementException( "Unable to close file writer : " + e );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private static Writer toWriter( URL url, String charsetName ) {
|
||||
private static Writer toWriter( URL url, String charsetName, boolean append ) {
|
||||
log.debug( "Attempting to resolve writer for URL : " + url );
|
||||
// technically only "strings corresponding to file URLs" are supported, which I take to mean URLs whose
|
||||
// protocol is "file"
|
||||
try {
|
||||
return ScriptTargetOutputToFile.toFileWriter( new File( url.toURI() ), charsetName );
|
||||
return ScriptTargetOutputToFile.toFileWriter( new File( url.toURI() ), charsetName, append );
|
||||
}
|
||||
catch (URISyntaxException e) {
|
||||
throw new SchemaManagementException(
|
||||
|
|
|
@ -130,7 +130,7 @@ public class SchemaManagementToolCoordinator {
|
|||
if ( scriptActionMap != null ) {
|
||||
scriptActionMap.forEach(
|
||||
(action, contributors) -> {
|
||||
performScriptAction( action, metadata, tool, serviceRegistry, executionOptions );
|
||||
performScriptAction( action, metadata, tool, serviceRegistry, executionOptions, configService );
|
||||
}
|
||||
);
|
||||
}
|
||||
|
@ -352,13 +352,15 @@ public class SchemaManagementToolCoordinator {
|
|||
Metadata metadata,
|
||||
SchemaManagementTool tool,
|
||||
ServiceRegistry serviceRegistry,
|
||||
ExecutionOptions executionOptions) {
|
||||
ExecutionOptions executionOptions,
|
||||
ConfigurationService configurationService) {
|
||||
switch ( scriptAction ) {
|
||||
case CREATE_ONLY: {
|
||||
final JpaTargetAndSourceDescriptor createDescriptor = buildScriptTargetDescriptor(
|
||||
executionOptions.getConfigurationValues(),
|
||||
CreateSettingSelector.INSTANCE,
|
||||
serviceRegistry
|
||||
serviceRegistry,
|
||||
configurationService
|
||||
);
|
||||
tool.getSchemaCreator( executionOptions.getConfigurationValues() ).doCreation(
|
||||
metadata,
|
||||
|
@ -374,7 +376,8 @@ public class SchemaManagementToolCoordinator {
|
|||
final JpaTargetAndSourceDescriptor dropDescriptor = buildScriptTargetDescriptor(
|
||||
executionOptions.getConfigurationValues(),
|
||||
DropSettingSelector.INSTANCE,
|
||||
serviceRegistry
|
||||
serviceRegistry,
|
||||
configurationService
|
||||
);
|
||||
tool.getSchemaDropper( executionOptions.getConfigurationValues() ).doDrop(
|
||||
metadata,
|
||||
|
@ -386,7 +389,8 @@ public class SchemaManagementToolCoordinator {
|
|||
final JpaTargetAndSourceDescriptor createDescriptor = buildScriptTargetDescriptor(
|
||||
executionOptions.getConfigurationValues(),
|
||||
CreateSettingSelector.INSTANCE,
|
||||
serviceRegistry
|
||||
serviceRegistry,
|
||||
configurationService
|
||||
);
|
||||
tool.getSchemaCreator( executionOptions.getConfigurationValues() ).doCreation(
|
||||
metadata,
|
||||
|
@ -401,7 +405,8 @@ public class SchemaManagementToolCoordinator {
|
|||
final JpaTargetAndSourceDescriptor dropDescriptor = buildScriptTargetDescriptor(
|
||||
executionOptions.getConfigurationValues(),
|
||||
DropSettingSelector.INSTANCE,
|
||||
serviceRegistry
|
||||
serviceRegistry,
|
||||
configurationService
|
||||
);
|
||||
tool.getSchemaDropper( executionOptions.getConfigurationValues() ).doDrop(
|
||||
metadata,
|
||||
|
@ -416,7 +421,8 @@ public class SchemaManagementToolCoordinator {
|
|||
final JpaTargetAndSourceDescriptor migrateDescriptor = buildScriptTargetDescriptor(
|
||||
executionOptions.getConfigurationValues(),
|
||||
MigrateSettingSelector.INSTANCE,
|
||||
serviceRegistry
|
||||
serviceRegistry,
|
||||
configurationService
|
||||
);
|
||||
tool.getSchemaMigrator( executionOptions.getConfigurationValues() ).doMigration(
|
||||
metadata,
|
||||
|
@ -435,7 +441,8 @@ public class SchemaManagementToolCoordinator {
|
|||
private static JpaTargetAndSourceDescriptor buildScriptTargetDescriptor(
|
||||
Map<?,?> configurationValues,
|
||||
SettingSelector settingSelector,
|
||||
ServiceRegistry serviceRegistry) {
|
||||
ServiceRegistry serviceRegistry,
|
||||
ConfigurationService configurationService) {
|
||||
final Object scriptSourceSetting = settingSelector.getScriptSourceSetting( configurationValues );
|
||||
final SourceType sourceType = SourceType.interpret(
|
||||
settingSelector.getSourceTypeSetting( configurationValues ),
|
||||
|
@ -455,10 +462,13 @@ public class SchemaManagementToolCoordinator {
|
|||
? Helper.interpretScriptSourceSetting( scriptSourceSetting, serviceRegistry.getService( ClassLoaderService.class ), charsetName )
|
||||
: null;
|
||||
|
||||
|
||||
boolean append = configurationService.getSetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_APPEND, StandardConverters.BOOLEAN, true );
|
||||
final ScriptTargetOutput scriptTargetOutput = Helper.interpretScriptTargetSetting(
|
||||
settingSelector.getScriptTargetSetting( configurationValues ),
|
||||
serviceRegistry.getService( ClassLoaderService.class ),
|
||||
charsetName
|
||||
charsetName,
|
||||
append
|
||||
);
|
||||
|
||||
return new JpaTargetAndSourceDescriptor() {
|
||||
|
|
|
@ -0,0 +1,170 @@
|
|||
/*
|
||||
* Hibernate, Relational Persistence for Idiomatic Java
|
||||
*
|
||||
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||
*/
|
||||
package org.hibernate.test.schemaupdate;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.File;
|
||||
import java.io.FileWriter;
|
||||
import java.nio.file.Files;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import javax.persistence.Entity;
|
||||
import javax.persistence.Id;
|
||||
|
||||
import org.hibernate.boot.MetadataSources;
|
||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||
import org.hibernate.boot.spi.MetadataImplementor;
|
||||
import org.hibernate.cfg.AvailableSettings;
|
||||
import org.hibernate.cfg.Environment;
|
||||
import org.hibernate.dialect.H2Dialect;
|
||||
import org.hibernate.engine.config.spi.ConfigurationService;
|
||||
import org.hibernate.service.ServiceRegistry;
|
||||
import org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator;
|
||||
|
||||
import org.hibernate.testing.RequiresDialect;
|
||||
import org.hibernate.testing.ServiceRegistryBuilder;
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.hamcrest.CoreMatchers.is;
|
||||
import static org.hamcrest.MatcherAssert.assertThat;
|
||||
import static org.hamcrest.core.StringContains.containsString;
|
||||
|
||||
@TestForIssue(jiraKey = "HHH-11817")
|
||||
@RequiresDialect(H2Dialect.class)
|
||||
public class SchemaCreationToOutputScriptTest extends BaseUnitTestCase {
|
||||
|
||||
private final String createTableMyEntity = "create table MyEntity";
|
||||
private final String createTableMySecondEntity = "create table MySecondEntity";
|
||||
|
||||
private File output;
|
||||
private ServiceRegistry serviceRegistry;
|
||||
private MetadataImplementor metadata;
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
output = File.createTempFile( "creation_script", ".sql" );
|
||||
output.deleteOnExit();
|
||||
|
||||
List<String> content = Arrays.asList(
|
||||
"This is the database creation script generated by Hibernate"
|
||||
, "This is the second line"
|
||||
, "This is the third line"
|
||||
, "This is the fourth line"
|
||||
, "This is the fifth line"
|
||||
, "This is the sixth line"
|
||||
, "This is the seventh line"
|
||||
, "This is the eighth line"
|
||||
, "This is the ninth line"
|
||||
);
|
||||
|
||||
try (BufferedWriter bw = new BufferedWriter( new FileWriter( output ) )) {
|
||||
for ( String s : content ) {
|
||||
bw.write( s );
|
||||
bw.write( System.lineSeparator() );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void createServiceRegistryAndMetadata(String append) {
|
||||
final StandardServiceRegistryBuilder standardServiceRegistryBuilder = new StandardServiceRegistryBuilder()
|
||||
.applySetting( Environment.FORMAT_SQL, "false" )
|
||||
.applySetting( Environment.HBM2DDL_SCRIPTS_ACTION, "create" )
|
||||
.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_TARGET, output.getAbsolutePath() );
|
||||
if ( append != null ) {
|
||||
standardServiceRegistryBuilder.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_APPEND, append );
|
||||
}
|
||||
|
||||
serviceRegistry = standardServiceRegistryBuilder.build();
|
||||
|
||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||
.addAnnotatedClass( MyEntity.class )
|
||||
.addAnnotatedClass( MySecondEntity.class )
|
||||
.buildMetadata();
|
||||
metadata.validate();
|
||||
}
|
||||
|
||||
@After
|
||||
public void tearDown() {
|
||||
ServiceRegistryBuilder.destroy( serviceRegistry );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeFalse() throws Exception {
|
||||
createServiceRegistryAndMetadata( "false" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 2 ) );
|
||||
assertThat( commands.get( 0 ), containsString( createTableMyEntity ) );
|
||||
assertThat( commands.get( 1 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeTrue() throws Exception {
|
||||
createServiceRegistryAndMetadata( "true" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 11 ) );
|
||||
assertThat( commands.get( 9 ), containsString( createTableMyEntity ) );
|
||||
assertThat( commands.get( 10 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultAppendMode() throws Exception {
|
||||
createServiceRegistryAndMetadata( null );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 11 ) );
|
||||
assertThat( commands.get( 9 ), containsString( createTableMyEntity ) );
|
||||
assertThat( commands.get( 10 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Entity(name = "MyEntity")
|
||||
public static class MyEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
@Entity(name = "MySecondEntity")
|
||||
public static class MySecondEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,170 @@
|
|||
/*
|
||||
* Hibernate, Relational Persistence for Idiomatic Java
|
||||
*
|
||||
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||
*/
|
||||
package org.hibernate.test.schemaupdate;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.File;
|
||||
import java.io.FileWriter;
|
||||
import java.nio.file.Files;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import javax.persistence.Entity;
|
||||
import javax.persistence.Id;
|
||||
|
||||
import org.hibernate.boot.MetadataSources;
|
||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||
import org.hibernate.boot.spi.MetadataImplementor;
|
||||
import org.hibernate.cfg.AvailableSettings;
|
||||
import org.hibernate.cfg.Environment;
|
||||
import org.hibernate.dialect.H2Dialect;
|
||||
import org.hibernate.engine.config.spi.ConfigurationService;
|
||||
import org.hibernate.service.ServiceRegistry;
|
||||
import org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator;
|
||||
|
||||
import org.hibernate.testing.RequiresDialect;
|
||||
import org.hibernate.testing.ServiceRegistryBuilder;
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.hamcrest.CoreMatchers.containsString;
|
||||
import static org.hamcrest.CoreMatchers.is;
|
||||
import static org.hamcrest.MatcherAssert.assertThat;
|
||||
|
||||
@TestForIssue(jiraKey = "HHH-11817")
|
||||
@RequiresDialect(H2Dialect.class)
|
||||
public class SchemaDropToOutputScriptTest extends BaseUnitTestCase {
|
||||
|
||||
private File output;
|
||||
private ServiceRegistry serviceRegistry;
|
||||
private MetadataImplementor metadata;
|
||||
private final String dropMyEntityTable = "drop table if exists MyEntity";
|
||||
private final String dropMySecondEntityTable = "drop table if exists MySecondEntity";
|
||||
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
output = File.createTempFile( "creation_script", ".sql" );
|
||||
output.deleteOnExit();
|
||||
List<String> content = Arrays.asList(
|
||||
"This is the database creation script generated by Hibernate"
|
||||
, "This is the second line"
|
||||
, "This is the third line"
|
||||
, "This is the fourth line"
|
||||
, "This is the fifth line"
|
||||
, "This is the sixth line"
|
||||
, "This is the seventh line"
|
||||
, "This is the eighth line"
|
||||
, "This is the ninth line"
|
||||
);
|
||||
|
||||
try (BufferedWriter bw = new BufferedWriter( new FileWriter( output ) )) {
|
||||
for ( String s : content ) {
|
||||
bw.write( s );
|
||||
bw.write( System.lineSeparator() );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void createServiceRegistryAndMetadata(String append) {
|
||||
final StandardServiceRegistryBuilder standardServiceRegistryBuilder = new StandardServiceRegistryBuilder()
|
||||
.applySetting( Environment.FORMAT_SQL, "false" )
|
||||
.applySetting( Environment.HBM2DDL_SCRIPTS_ACTION, "drop" )
|
||||
.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_DROP_TARGET, output.getAbsolutePath() );
|
||||
|
||||
if ( append != null ) {
|
||||
standardServiceRegistryBuilder.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_APPEND, append );
|
||||
}
|
||||
|
||||
serviceRegistry = standardServiceRegistryBuilder.build();
|
||||
|
||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||
.addAnnotatedClass( MyEntity.class )
|
||||
.addAnnotatedClass( MySecondEntity.class )
|
||||
.buildMetadata();
|
||||
metadata.validate();
|
||||
}
|
||||
|
||||
@After
|
||||
public void tearDown() {
|
||||
ServiceRegistryBuilder.destroy( serviceRegistry );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeFalse() throws Exception {
|
||||
createServiceRegistryAndMetadata( "false" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 2 ) );
|
||||
assertThat( commands.get( 0 ), containsString( dropMyEntityTable ) );
|
||||
assertThat( commands.get( 1 ), containsString( dropMySecondEntityTable ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeTrue() throws Exception {
|
||||
createServiceRegistryAndMetadata( "true" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 11 ) );
|
||||
assertThat( commands.get( 9 ), containsString( dropMyEntityTable ) );
|
||||
assertThat( commands.get( 10 ), containsString( dropMySecondEntityTable ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultAppendMode() throws Exception {
|
||||
createServiceRegistryAndMetadata( null );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 11 ) );
|
||||
assertThat( commands.get( 9 ), containsString( dropMyEntityTable ) );
|
||||
assertThat( commands.get( 10 ), containsString( dropMySecondEntityTable ) );
|
||||
}
|
||||
|
||||
@Entity(name = "MyEntity")
|
||||
public static class MyEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
@Entity(name = "MySecondEntity")
|
||||
public static class MySecondEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,188 @@
|
|||
/*
|
||||
* Hibernate, Relational Persistence for Idiomatic Java
|
||||
*
|
||||
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||
*/
|
||||
package org.hibernate.test.schemaupdate;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.File;
|
||||
import java.io.FileWriter;
|
||||
import java.nio.file.Files;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import javax.persistence.Entity;
|
||||
import javax.persistence.Id;
|
||||
|
||||
import org.hibernate.SessionFactory;
|
||||
import org.hibernate.boot.MetadataSources;
|
||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||
import org.hibernate.boot.spi.MetadataImplementor;
|
||||
import org.hibernate.cfg.AvailableSettings;
|
||||
import org.hibernate.cfg.Environment;
|
||||
import org.hibernate.dialect.H2Dialect;
|
||||
import org.hibernate.engine.config.spi.ConfigurationService;
|
||||
import org.hibernate.service.ServiceRegistry;
|
||||
import org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator;
|
||||
|
||||
import org.hibernate.testing.RequiresDialect;
|
||||
import org.hibernate.testing.ServiceRegistryBuilder;
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.hamcrest.CoreMatchers.containsString;
|
||||
import static org.hamcrest.CoreMatchers.is;
|
||||
import static org.hamcrest.MatcherAssert.assertThat;
|
||||
|
||||
@TestForIssue(jiraKey = "HHH-11817")
|
||||
@RequiresDialect(H2Dialect.class)
|
||||
public class SchemaMigrationToOutputScriptTest extends BaseUnitTestCase {
|
||||
|
||||
private final String createTableMySecondEntity = "create table MySecondEntity";
|
||||
|
||||
private File output;
|
||||
private ServiceRegistry serviceRegistry;
|
||||
private MetadataImplementor metadata;
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
output = File.createTempFile( "creation_script", ".sql" );
|
||||
output.deleteOnExit();
|
||||
|
||||
List<String> content = Arrays.asList(
|
||||
"This is the database creation script generated by Hibernate"
|
||||
, "This is the second line"
|
||||
, "This is the third line"
|
||||
, "This is the fourth line"
|
||||
, "This is the fifth line"
|
||||
, "This is the sixth line"
|
||||
, "This is the seventh line"
|
||||
, "This is the eighth line"
|
||||
, "This is the ninth line"
|
||||
);
|
||||
|
||||
try (BufferedWriter bw = new BufferedWriter( new FileWriter( output ) )) {
|
||||
for ( String s : content ) {
|
||||
bw.write( s );
|
||||
bw.write( System.lineSeparator() );
|
||||
}
|
||||
}
|
||||
|
||||
serviceRegistry = new StandardServiceRegistryBuilder().applySetting(
|
||||
AvailableSettings.HBM2DDL_AUTO,
|
||||
"create-only"
|
||||
)
|
||||
.build();
|
||||
|
||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||
.addAnnotatedClass( MyEntity.class )
|
||||
.buildMetadata();
|
||||
final SessionFactory sessionFactory = metadata.buildSessionFactory();
|
||||
sessionFactory.close();
|
||||
}
|
||||
|
||||
private void createServiceRegistryAndMetadata(String append) {
|
||||
final StandardServiceRegistryBuilder standardServiceRegistryBuilder = new StandardServiceRegistryBuilder()
|
||||
.applySetting( Environment.FORMAT_SQL, "false" )
|
||||
.applySetting( Environment.HBM2DDL_SCRIPTS_ACTION, "update" )
|
||||
.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_TARGET, output.getAbsolutePath() );
|
||||
|
||||
if ( append != null ) {
|
||||
standardServiceRegistryBuilder.applySetting( AvailableSettings.HBM2DDL_SCRIPTS_CREATE_APPEND, append );
|
||||
}
|
||||
|
||||
serviceRegistry = standardServiceRegistryBuilder.build();
|
||||
|
||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||
.addAnnotatedClass( MyEntity.class )
|
||||
.addAnnotatedClass( MySecondEntity.class )
|
||||
.buildMetadata();
|
||||
metadata.validate();
|
||||
}
|
||||
|
||||
@After
|
||||
public void tearDown() {
|
||||
ServiceRegistryBuilder.destroy( serviceRegistry );
|
||||
serviceRegistry = new StandardServiceRegistryBuilder().applySetting( AvailableSettings.HBM2DDL_AUTO, "drop" )
|
||||
.build();
|
||||
|
||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||
.addAnnotatedClass( MyEntity.class )
|
||||
.buildMetadata();
|
||||
final SessionFactory sessionFactory = metadata.buildSessionFactory();
|
||||
sessionFactory.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeFalse() throws Exception {
|
||||
createServiceRegistryAndMetadata( "false" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 1 ) );
|
||||
assertThat( commands.get( 0 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAppendModeTrue() throws Exception {
|
||||
createServiceRegistryAndMetadata( "true" );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 10 ) );
|
||||
assertThat( commands.get( 9 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultAppendMode() throws Exception {
|
||||
createServiceRegistryAndMetadata( null );
|
||||
HashMap properties = new HashMap<>();
|
||||
properties.putAll( serviceRegistry.getService( ConfigurationService.class ).getSettings() );
|
||||
|
||||
SchemaManagementToolCoordinator.process(
|
||||
metadata,
|
||||
serviceRegistry,
|
||||
properties,
|
||||
null
|
||||
);
|
||||
List<String> commands = Files.readAllLines( output.toPath() );
|
||||
assertThat( commands.size(), is( 10 ) );
|
||||
assertThat( commands.get( 9 ), containsString( createTableMySecondEntity ) );
|
||||
}
|
||||
|
||||
@Entity(name = "MyEntity")
|
||||
public static class MyEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
@Entity(name = "MySecondEntity")
|
||||
public static class MySecondEntity {
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
private String name;
|
||||
}
|
||||
|
||||
}
|
|
@ -75,6 +75,10 @@ jar {
|
|||
}
|
||||
}
|
||||
|
||||
sourcesJar {
|
||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||
}
|
||||
|
||||
task testJar(type: Jar, dependsOn: testClasses) {
|
||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||
archiveClassifier.set( 'test' )
|
||||
|
|
|
@ -42,4 +42,9 @@ public class CockroachDB202SpatialDialect extends CockroachDB201Dialect implemen
|
|||
delegateContributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( isSpatial( typeCode1 ) && isSpatial( typeCode2 ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -74,4 +74,9 @@ public interface CockroachSpatialDialectTrait extends SpatialDialect {
|
|||
return DELEGATE.supports( function );
|
||||
}
|
||||
|
||||
|
||||
default boolean isSpatial(int typeCode) {
|
||||
return DELEGATE.isSpatial( typeCode );
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -7,6 +7,8 @@
|
|||
|
||||
package org.hibernate.spatial.dialect.postgis;
|
||||
|
||||
import java.sql.Types;
|
||||
|
||||
import org.hibernate.spatial.SpatialDialect;
|
||||
import org.hibernate.spatial.SpatialFunction;
|
||||
import org.hibernate.spatial.dialect.SpatialFunctionsRegistry;
|
||||
|
@ -125,4 +127,13 @@ interface PGSpatialDialectTrait extends SpatialDialect {
|
|||
default boolean supports(SpatialFunction function) {
|
||||
return support.supports( function );
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks whether the typeCode is (potentially) the code for a spatial type
|
||||
* @param typeCode the JDBC type code
|
||||
* @return if the typecode corresponds with a spatialt type
|
||||
*/
|
||||
default boolean isSpatial(int typeCode){
|
||||
return support.isSpatial( typeCode );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
package org.hibernate.spatial.dialect.postgis;
|
||||
|
||||
import java.sql.Types;
|
||||
import java.util.Map;
|
||||
|
||||
import org.hibernate.boot.model.TypeContributions;
|
||||
|
@ -36,4 +37,11 @@ public class PostgisPG10Dialect extends PostgreSQL10Dialect implements PGSpatial
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( isSpatial( typeCode1 ) && isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -48,6 +48,11 @@ public class PostgisPG82Dialect extends PostgreSQL82Dialect implements SpatialDi
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getSpatialRelateSQL(String columnName, int spatialRelation) {
|
||||
|
|
|
@ -48,6 +48,12 @@ public class PostgisPG91Dialect extends PostgreSQL91Dialect implements SpatialDi
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
|
@ -48,6 +48,12 @@ public class PostgisPG92Dialect extends PostgreSQL92Dialect implements SpatialDi
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
|
@ -48,6 +48,12 @@ public class PostgisPG93Dialect extends PostgreSQL93Dialect implements SpatialDi
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
|
@ -48,6 +48,12 @@ public class PostgisPG94Dialect extends PostgreSQL94Dialect implements SpatialDi
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
|
@ -42,4 +42,9 @@ public class PostgisPG95Dialect extends PostgreSQL95Dialect implements PGSpatial
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( isSpatial( typeCode1 ) && isSpatial( typeCode2 ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -48,6 +48,12 @@ public class PostgisPG9Dialect extends PostgreSQL9Dialect implements SpatialDial
|
|||
support.contributeTypes( typeContributions, serviceRegistry );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equivalentTypes(int typeCode1, int typeCode2) {
|
||||
return super.equivalentTypes( typeCode1, typeCode2 ) ||
|
||||
( support.isSpatial( typeCode1 ) && support.isSpatial( typeCode2 ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
package org.hibernate.spatial.dialect.postgis;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.sql.Types;
|
||||
|
||||
import org.hibernate.boot.model.TypeContributions;
|
||||
import org.hibernate.service.ServiceRegistry;
|
||||
|
@ -47,6 +48,10 @@ public class PostgisSupport implements SpatialDialect, Serializable {
|
|||
return postgisFunctions;
|
||||
}
|
||||
|
||||
public boolean isSpatial(int typeCode){
|
||||
return typeCode == Types.OTHER || typeCode == PGGeometryTypeDescriptor.INSTANCE_WKB_1.getSqlType();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the SQL fragment for the SQL WHERE-clause when parsing
|
||||
* <code>org.hibernatespatial.criterion.SpatialRelateExpression</code>s
|
||||
|
|
Loading…
Reference in New Issue