IDEMPIERE-3842 Cannot run Synchronize Column on oracle CLOB columns
This commit is contained in:
parent
349c764730
commit
7c023a5ac3
|
@ -20,6 +20,7 @@ import java.math.BigDecimal;
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.DatabaseMetaData;
|
import java.sql.DatabaseMetaData;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.Types;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import org.compiere.model.MColumn;
|
import org.compiere.model.MColumn;
|
||||||
|
@ -110,6 +111,21 @@ public class ColumnSync extends SvrProcess
|
||||||
// update existing column
|
// update existing column
|
||||||
boolean notNull = DatabaseMetaData.columnNoNulls == rs.getInt("NULLABLE");
|
boolean notNull = DatabaseMetaData.columnNoNulls == rs.getInt("NULLABLE");
|
||||||
sql = column.getSQLModify(table, column.isMandatory() != notNull);
|
sql = column.getSQLModify(table, column.isMandatory() != notNull);
|
||||||
|
if (DB.isOracle()) {
|
||||||
|
// IDEMPIERE-3842 problem with oracle alter CLOB or BLOB
|
||||||
|
int actualType = rs.getInt("DATA_TYPE");
|
||||||
|
if (actualType == Types.CLOB) {
|
||||||
|
if (sql.contains(" MODIFY " + column.getColumnName() + " CLOB")) {
|
||||||
|
// trying to make CLOB a column that is already a CLOB
|
||||||
|
sql = sql.replaceFirst(" MODIFY " + column.getColumnName() + " CLOB", " MODIFY " + column.getColumnName());
|
||||||
|
}
|
||||||
|
} else if (actualType == Types.BLOB) {
|
||||||
|
if (sql.contains(" MODIFY " + column.getColumnName() + " BLOB")) {
|
||||||
|
// trying to make BLOB a column that is already a BLOB
|
||||||
|
sql = sql.replaceFirst(" MODIFY " + column.getColumnName() + " BLOB", " MODIFY " + column.getColumnName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
DB.close(rs);
|
DB.close(rs);
|
||||||
|
|
|
@ -763,7 +763,7 @@ public class MColumn extends X_AD_Column
|
||||||
foreignTable = "M_AttributeSetInstance";
|
foreignTable = "M_AttributeSetInstance";
|
||||||
} else if (DisplayType.Assignment == refid) {
|
} else if (DisplayType.Assignment == refid) {
|
||||||
foreignTable = "S_ResourceAssignment";
|
foreignTable = "S_ResourceAssignment";
|
||||||
} else if (DisplayType.Image == refid) {
|
} else if (DisplayType.Image == refid && !"BinaryData".equals(getColumnName())) {
|
||||||
foreignTable = "AD_Image";
|
foreignTable = "AD_Image";
|
||||||
} else if (DisplayType.Chart == refid) {
|
} else if (DisplayType.Chart == refid) {
|
||||||
foreignTable = "AD_Chart";
|
foreignTable = "AD_Chart";
|
||||||
|
|
|
@ -20,6 +20,7 @@ import java.sql.Connection;
|
||||||
import java.sql.DatabaseMetaData;
|
import java.sql.DatabaseMetaData;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Types;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
@ -245,10 +246,23 @@ public class ColumnElementHandler extends AbstractElementHandler {
|
||||||
if (rsc.next()) {
|
if (rsc.next()) {
|
||||||
if (doAlter) {
|
if (doAlter) {
|
||||||
// update existing column
|
// update existing column
|
||||||
boolean notNull = DatabaseMetaData.columnNoNulls == rsc
|
boolean notNull = DatabaseMetaData.columnNoNulls == rsc.getInt("NULLABLE");
|
||||||
.getInt("NULLABLE");
|
sql = column.getSQLModify(table, column.isMandatory() != notNull);
|
||||||
sql = column.getSQLModify(table,
|
if (DB.isOracle()) {
|
||||||
column.isMandatory() != notNull);
|
// IDEMPIERE-3842 problem with oracle alter CLOB or BLOB
|
||||||
|
int actualType = rsc.getInt("DATA_TYPE");
|
||||||
|
if (actualType == Types.CLOB) {
|
||||||
|
if (sql.contains(" MODIFY " + column.getColumnName() + " CLOB")) {
|
||||||
|
// trying to make CLOB a column that is already a CLOB
|
||||||
|
sql = sql.replaceFirst(" MODIFY " + column.getColumnName() + " CLOB", " MODIFY " + column.getColumnName());
|
||||||
|
}
|
||||||
|
} else if (actualType == Types.BLOB) {
|
||||||
|
if (sql.contains(" MODIFY " + column.getColumnName() + " BLOB")) {
|
||||||
|
// trying to make BLOB a column that is already a BLOB
|
||||||
|
sql = sql.replaceFirst(" MODIFY " + column.getColumnName() + " BLOB", " MODIFY " + column.getColumnName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// No existing column
|
// No existing column
|
||||||
|
|
|
@ -369,6 +369,9 @@ public class DB_Oracle implements AdempiereDatabase
|
||||||
public String convertStatement (String oraStatement)
|
public String convertStatement (String oraStatement)
|
||||||
{
|
{
|
||||||
Convert.logMigrationScript(oraStatement, null);
|
Convert.logMigrationScript(oraStatement, null);
|
||||||
|
if ("true".equals(System.getProperty("org.idempiere.db.oracle.debug"))) {
|
||||||
|
log.warning("Oracle -> " + oraStatement);
|
||||||
|
}
|
||||||
return oraStatement;
|
return oraStatement;
|
||||||
} // convertStatement
|
} // convertStatement
|
||||||
|
|
||||||
|
|
|
@ -2,14 +2,22 @@ package org.compiere.dbPort;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import org.compiere.util.CLogger;
|
||||||
|
|
||||||
public class Convert_Oracle extends Convert {
|
public class Convert_Oracle extends Convert {
|
||||||
|
|
||||||
|
/** Logger */
|
||||||
|
private static CLogger log = CLogger.getCLogger(Convert_Oracle.class);
|
||||||
|
|
||||||
public Convert_Oracle() {}
|
public Convert_Oracle() {}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected ArrayList<String> convertStatement(String sqlStatement) {
|
protected ArrayList<String> convertStatement(String sqlStatement) {
|
||||||
ArrayList<String> result = new ArrayList<String>();
|
ArrayList<String> result = new ArrayList<String>();
|
||||||
result.add(sqlStatement);
|
result.add(sqlStatement);
|
||||||
|
if ("true".equals(System.getProperty("org.idempiere.db.oracle.debug"))) {
|
||||||
|
log.warning("Oracle -> " + sqlStatement);
|
||||||
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue