HHH-18604 Fix some issues with older database versions
This commit is contained in:
parent
ddadad2dac
commit
11d134ae38
|
@ -512,8 +512,9 @@ public class CockroachLegacyDialect extends Dialect {
|
||||||
functionFactory.jsonRemove_cockroachdb();
|
functionFactory.jsonRemove_cockroachdb();
|
||||||
functionFactory.jsonReplace_postgresql();
|
functionFactory.jsonReplace_postgresql();
|
||||||
functionFactory.jsonInsert_postgresql();
|
functionFactory.jsonInsert_postgresql();
|
||||||
functionFactory.jsonMergepatch_postgresql();
|
// No support for WITH clause in subquery: https://github.com/cockroachdb/cockroach/issues/131011
|
||||||
functionFactory.jsonArrayAppend_postgresql();
|
// functionFactory.jsonMergepatch_postgresql();
|
||||||
|
functionFactory.jsonArrayAppend_postgresql( false );
|
||||||
functionFactory.jsonArrayInsert_postgresql();
|
functionFactory.jsonArrayInsert_postgresql();
|
||||||
|
|
||||||
// Postgres uses # instead of ^ for XOR
|
// Postgres uses # instead of ^ for XOR
|
||||||
|
|
|
@ -662,8 +662,11 @@ public class PostgreSQLLegacyDialect extends Dialect {
|
||||||
functionFactory.jsonRemove_postgresql();
|
functionFactory.jsonRemove_postgresql();
|
||||||
functionFactory.jsonReplace_postgresql();
|
functionFactory.jsonReplace_postgresql();
|
||||||
functionFactory.jsonInsert_postgresql();
|
functionFactory.jsonInsert_postgresql();
|
||||||
functionFactory.jsonMergepatch_postgresql();
|
if ( getVersion().isSameOrAfter( 13 ) ) {
|
||||||
functionFactory.jsonArrayAppend_postgresql();
|
// Requires support for WITH clause in subquery which only 13+ provides
|
||||||
|
functionFactory.jsonMergepatch_postgresql();
|
||||||
|
}
|
||||||
|
functionFactory.jsonArrayAppend_postgresql( getVersion().isSameOrAfter( 13 ) );
|
||||||
functionFactory.jsonArrayInsert_postgresql();
|
functionFactory.jsonArrayInsert_postgresql();
|
||||||
|
|
||||||
if ( getVersion().isSameOrAfter( 9, 4 ) ) {
|
if ( getVersion().isSameOrAfter( 9, 4 ) ) {
|
||||||
|
|
|
@ -479,8 +479,9 @@ public class CockroachDialect extends Dialect {
|
||||||
functionFactory.jsonRemove_cockroachdb();
|
functionFactory.jsonRemove_cockroachdb();
|
||||||
functionFactory.jsonReplace_postgresql();
|
functionFactory.jsonReplace_postgresql();
|
||||||
functionFactory.jsonInsert_postgresql();
|
functionFactory.jsonInsert_postgresql();
|
||||||
functionFactory.jsonMergepatch_postgresql();
|
// No support for WITH clause in subquery: https://github.com/cockroachdb/cockroach/issues/131011
|
||||||
functionFactory.jsonArrayAppend_postgresql();
|
// functionFactory.jsonMergepatch_postgresql();
|
||||||
|
functionFactory.jsonArrayAppend_postgresql( false );
|
||||||
functionFactory.jsonArrayInsert_postgresql();
|
functionFactory.jsonArrayInsert_postgresql();
|
||||||
|
|
||||||
// Postgres uses # instead of ^ for XOR
|
// Postgres uses # instead of ^ for XOR
|
||||||
|
|
|
@ -623,8 +623,11 @@ public class PostgreSQLDialect extends Dialect {
|
||||||
functionFactory.jsonRemove_postgresql();
|
functionFactory.jsonRemove_postgresql();
|
||||||
functionFactory.jsonReplace_postgresql();
|
functionFactory.jsonReplace_postgresql();
|
||||||
functionFactory.jsonInsert_postgresql();
|
functionFactory.jsonInsert_postgresql();
|
||||||
functionFactory.jsonMergepatch_postgresql();
|
if ( getVersion().isSameOrAfter( 13 ) ) {
|
||||||
functionFactory.jsonArrayAppend_postgresql();
|
// Requires support for WITH clause in subquery which only 13+ provides
|
||||||
|
functionFactory.jsonMergepatch_postgresql();
|
||||||
|
}
|
||||||
|
functionFactory.jsonArrayAppend_postgresql( getVersion().isSameOrAfter( 13 ) );
|
||||||
functionFactory.jsonArrayInsert_postgresql();
|
functionFactory.jsonArrayInsert_postgresql();
|
||||||
|
|
||||||
functionFactory.makeDateTimeTimestamp();
|
functionFactory.makeDateTimeTimestamp();
|
||||||
|
|
|
@ -4018,8 +4018,8 @@ public class CommonFunctionFactory {
|
||||||
/**
|
/**
|
||||||
* PostgreSQL json_array_append() function
|
* PostgreSQL json_array_append() function
|
||||||
*/
|
*/
|
||||||
public void jsonArrayAppend_postgresql() {
|
public void jsonArrayAppend_postgresql(boolean supportsLax) {
|
||||||
functionRegistry.register( "json_array_append", new PostgreSQLJsonArrayAppendFunction( typeConfiguration ) );
|
functionRegistry.register( "json_array_append", new PostgreSQLJsonArrayAppendFunction( supportsLax, typeConfiguration ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -21,8 +21,11 @@ import org.hibernate.type.spi.TypeConfiguration;
|
||||||
*/
|
*/
|
||||||
public class PostgreSQLJsonArrayAppendFunction extends AbstractJsonArrayAppendFunction {
|
public class PostgreSQLJsonArrayAppendFunction extends AbstractJsonArrayAppendFunction {
|
||||||
|
|
||||||
public PostgreSQLJsonArrayAppendFunction(TypeConfiguration typeConfiguration) {
|
private final boolean supportsLax;
|
||||||
|
|
||||||
|
public PostgreSQLJsonArrayAppendFunction(boolean supportsLax, TypeConfiguration typeConfiguration) {
|
||||||
super( typeConfiguration );
|
super( typeConfiguration );
|
||||||
|
this.supportsLax = supportsLax;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -34,7 +37,14 @@ public class PostgreSQLJsonArrayAppendFunction extends AbstractJsonArrayAppendFu
|
||||||
final Expression json = (Expression) arguments.get( 0 );
|
final Expression json = (Expression) arguments.get( 0 );
|
||||||
final Expression jsonPath = (Expression) arguments.get( 1 );
|
final Expression jsonPath = (Expression) arguments.get( 1 );
|
||||||
final SqlAstNode value = arguments.get( 2 );
|
final SqlAstNode value = arguments.get( 2 );
|
||||||
sqlAppender.appendSql( "(select jsonb_set_lax(t.d,t.p,(t.d)#>t.p||" );
|
sqlAppender.appendSql( "(select " );
|
||||||
|
if ( supportsLax ) {
|
||||||
|
sqlAppender.appendSql( "jsonb_set_lax" );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
sqlAppender.appendSql( "case when t.d#>t.p is not null then jsonb_set" );
|
||||||
|
}
|
||||||
|
sqlAppender.appendSql( "(t.d,t.p,(t.d)#>t.p||" );
|
||||||
if ( value instanceof Literal && ( (Literal) value ).getLiteralValue() == null ) {
|
if ( value instanceof Literal && ( (Literal) value ).getLiteralValue() == null ) {
|
||||||
sqlAppender.appendSql( "null::jsonb" );
|
sqlAppender.appendSql( "null::jsonb" );
|
||||||
}
|
}
|
||||||
|
@ -47,7 +57,14 @@ public class PostgreSQLJsonArrayAppendFunction extends AbstractJsonArrayAppendFu
|
||||||
}
|
}
|
||||||
sqlAppender.appendSql( ')' );
|
sqlAppender.appendSql( ')' );
|
||||||
}
|
}
|
||||||
sqlAppender.appendSql( ",false,'return_target') from (values(" );
|
sqlAppender.appendSql( ",false" );
|
||||||
|
if ( supportsLax ) {
|
||||||
|
sqlAppender.appendSql( ",'return_target')" );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
sqlAppender.appendSql( ") else t.d end" );
|
||||||
|
}
|
||||||
|
sqlAppender.appendSql( " from (values(" );
|
||||||
final boolean needsCast = !isJsonType( json );
|
final boolean needsCast = !isJsonType( json );
|
||||||
if ( needsCast ) {
|
if ( needsCast ) {
|
||||||
sqlAppender.appendSql( "cast(" );
|
sqlAppender.appendSql( "cast(" );
|
||||||
|
|
|
@ -33,7 +33,6 @@ public class PostgreSQLJsonRemoveFunction extends AbstractJsonRemoveFunction {
|
||||||
SqlAstTranslator<?> translator) {
|
SqlAstTranslator<?> translator) {
|
||||||
final Expression json = (Expression) arguments.get( 0 );
|
final Expression json = (Expression) arguments.get( 0 );
|
||||||
final Expression jsonPath = (Expression) arguments.get( 1 );
|
final Expression jsonPath = (Expression) arguments.get( 1 );
|
||||||
sqlAppender.appendSql( "jsonb_set_lax(" );
|
|
||||||
final boolean needsCast = !isJsonType( json ) && json instanceof JdbcParameter;
|
final boolean needsCast = !isJsonType( json ) && json instanceof JdbcParameter;
|
||||||
if ( needsCast ) {
|
if ( needsCast ) {
|
||||||
sqlAppender.appendSql( "cast(" );
|
sqlAppender.appendSql( "cast(" );
|
||||||
|
@ -42,7 +41,7 @@ public class PostgreSQLJsonRemoveFunction extends AbstractJsonRemoveFunction {
|
||||||
if ( needsCast ) {
|
if ( needsCast ) {
|
||||||
sqlAppender.appendSql( " as jsonb)" );
|
sqlAppender.appendSql( " as jsonb)" );
|
||||||
}
|
}
|
||||||
sqlAppender.appendSql( ',' );
|
sqlAppender.appendSql( "#-" );
|
||||||
List<JsonPathHelper.JsonPathElement> jsonPathElements =
|
List<JsonPathHelper.JsonPathElement> jsonPathElements =
|
||||||
JsonPathHelper.parseJsonPathElements( translator.getLiteralValue( jsonPath ) );
|
JsonPathHelper.parseJsonPathElements( translator.getLiteralValue( jsonPath ) );
|
||||||
sqlAppender.appendSql( "array" );
|
sqlAppender.appendSql( "array" );
|
||||||
|
@ -63,7 +62,7 @@ public class PostgreSQLJsonRemoveFunction extends AbstractJsonRemoveFunction {
|
||||||
}
|
}
|
||||||
separator = ',';
|
separator = ',';
|
||||||
}
|
}
|
||||||
sqlAppender.appendSql( "]::text[],null,true,'delete_key')" );
|
sqlAppender.appendSql( "]::text[]" );
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isJsonType(Expression expression) {
|
private boolean isJsonType(Expression expression) {
|
||||||
|
|
Loading…
Reference in New Issue