package liquibase.datatype.core;
import liquibase.database.Database;
import liquibase.database.core.*;
import liquibase.datatype.DataTypeInfo;
import liquibase.datatype.DatabaseDataType;
import liquibase.datatype.LiquibaseDataType;
import liquibase.util.StringUtils;
@DataTypeInfo(name="currency", aliases = {"money", "smallmoney"}, minParameters = 0, maxParameters = 0, priority = LiquibaseDataType.PRIORITY_DEFAULT)
public class CurrencyType extends LiquibaseDataType {
@Override
public DatabaseDataType toDatabaseDataType(Database database) {
String originalDefinition = StringUtils.trimToEmpty(getRawDefinition());
if (database instanceof MSSQLDatabase) {
if (originalDefinition.toLowerCase().startsWith("smallmoney")
|| originalDefinition.toLowerCase().startsWith("[smallmoney]")) {
return new DatabaseDataType(database.escapeDataTypeName("smallmoney"));
}
return new DatabaseDataType(database.escapeDataTypeName("money"));
}
if (database instanceof InformixDatabase || database instanceof SybaseASADatabase || database instanceof SybaseDatabase) {
return new DatabaseDataType("MONEY");
}
if (database instanceof OracleDatabase) {
return new DatabaseDataType("NUMBER", 15, 2);
}
if (database instanceof DB2Database) {
return new DatabaseDataType("DECIMAL", 19,4);
}
if (database instanceof FirebirdDatabase) {
return new DatabaseDataType("DECIMAL", 18, 4);
}
if (database instanceof SQLiteDatabase) {
return new DatabaseDataType("REAL");
}
return new DatabaseDataType("DECIMAL");
}
}