Skip to content

Commit

Permalink
0005483: Toggle to convert TEXT to VARCHAR in MS SQL (#186)
Browse files Browse the repository at this point in the history
* Set env var USE_VARCHAR_FOR_TEXT to create varchar for text types

* Use property for setting text-to-varchar

* Use short if for N-type
  • Loading branch information
scornelissen85 committed Sep 30, 2022
1 parent 2679844 commit b47dcc3
Showing 1 changed file with 6 additions and 0 deletions.
Expand Up @@ -21,6 +21,7 @@
package org.jumpmind.db.platform.mssql;

import java.sql.Types;
import java.util.Map;

import org.jumpmind.db.model.Column;
import org.jumpmind.db.model.Table;
Expand Down Expand Up @@ -87,6 +88,7 @@ protected void dropColumnChangeDefaults(Table sourceTable, Column sourceColumn,

@Override
public String getSqlType(Column column) {
boolean useVarcharForText = System.getProperty("mssql.use.varchar.for.lob", "false").equalsIgnoreCase("true");
String sqlType = super.getSqlType(column);
if (column.getMappedTypeCode() == Types.VARBINARY && column.getSizeAsInt() > 8000) {
sqlType = "VARBINARY(MAX)";
Expand All @@ -96,6 +98,10 @@ public String getSqlType(Column column) {
sqlType = "NVARCHAR(MAX)";
} else if (column.getMappedTypeCode() == Types.DECIMAL && column.getSizeAsInt() > 38) {
sqlType = String.format("DECIMAL(38,%d)", column.getScale());
} else if (useVarcharForText && (column.getMappedTypeCode() == Types.LONGVARCHAR || column.getMappedTypeCode() == Types.LONGNVARCHAR || column
.getMappedTypeCode() == Types.CLOB)) {
sqlType = (column.getMappedTypeCode() == Types.LONGNVARCHAR) ? "N" : "";
sqlType += "VARCHAR(MAX)";
}
return sqlType;
}
Expand Down

0 comments on commit b47dcc3

Please sign in to comment.