@Override public Object overrideDriverTypeConversion(MetaModel mm, String attributeName, Object value) { // Oracle returns java.sql.Timestamp for DATE values if (value instanceof Timestamp) { String typeName = mm.getColumnMetadata().get(attributeName).getTypeName(); if ("DATE".equalsIgnoreCase(typeName)) { return Convert.toSqlDate(value); } } return value; }
@Override public Object overrideDriverTypeConversion(MetaModel mm, String attributeName, Object value) { // SQLite returns DATE and DATETIME as String or Number values if (value instanceof String && !Util.blank(value) || value instanceof Number) { String typeName = mm.getColumnMetadata().get(attributeName).getTypeName(); if ("DATE".equalsIgnoreCase(typeName)) { return Convert.toSqlDate(value); } else if ("DATETIME".equalsIgnoreCase(typeName)) { return Convert.toTimestamp(value); } else if ("TIME".equalsIgnoreCase(typeName)) { return Convert.toTime(value); } } return value; }
/** * Gets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the attribute value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute to convert * @return value converted to <code>java.sql.Date</code> */ public java.sql.Date getDate(String attributeName) { Object value = getRaw(attributeName); Converter<Object, java.sql.Date> converter = modelRegistryLocal.converterForValue( attributeName, value, java.sql.Date.class); return converter != null ? converter.convert(value) : Convert.toSqlDate(value); }
/** * Sets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute. * @param value value to convert. * @return reference to this model. */ public <T extends Model> T setDate(String attributeName, Object value) { Converter<Object, java.sql.Date> converter = modelRegistryLocal.converterForValue( attributeName, value, java.sql.Date.class); return setRaw(attributeName, converter != null ? converter.convert(value) : Convert.toSqlDate(value)); }
@Override public Object overrideDriverTypeConversion(MetaModel mm, String attributeName, Object value) { // Oracle returns java.sql.Timestamp for DATE values if (value instanceof Timestamp) { String typeName = mm.getColumnMetadata().get(attributeName).getTypeName(); if ("DATE".equalsIgnoreCase(typeName)) { return Convert.toSqlDate(value); } } return value; }
@Override public Object overrideDriverTypeConversion(MetaModel mm, String attributeName, Object value) { // SQLite returns DATE and DATETIME as String or Number values if (value instanceof String || value instanceof Number) { String typeName = mm.getColumnMetadata().get(attributeName).getTypeName(); if ("DATE".equalsIgnoreCase(typeName)) { return Convert.toSqlDate(value); } else if ("DATETIME".equalsIgnoreCase(typeName)) { return Convert.toTimestamp(value); } else if ("TIME".equalsIgnoreCase(typeName)) { return Convert.toTime(value); } } return value; }
@Override public Object overrideDriverTypeConversion(MetaModel mm, String attributeName, Object value) { // SQLite returns DATE and DATETIME as String or Number values if (value instanceof String && !Util.blank(value) || value instanceof Number) { String typeName = mm.getColumnMetadata().get(attributeName).getTypeName(); if ("DATE".equalsIgnoreCase(typeName)) { return Convert.toSqlDate(value); } else if ("DATETIME".equalsIgnoreCase(typeName)) { return Convert.toTimestamp(value); } else if ("TIME".equalsIgnoreCase(typeName)) { return Convert.toTime(value); } } return value; }
/** * Sets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute. * @param value value to convert. * @return reference to this model. */ public <T extends Model> T setDate(String attributeName, Object value) { Converter<Object, java.sql.Date> converter = modelRegistryLocal().converterForValue( attributeName, value, java.sql.Date.class); return setRaw(attributeName, converter != null ? converter.convert(value) : Convert.toSqlDate(value)); }
/** * Gets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the attribute value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute to convert * @return value converted to <code>java.sql.Date</code> */ public java.sql.Date getDate(String attributeName) { Object value = getRaw(attributeName); Converter<Object, java.sql.Date> converter = modelRegistryLocal().converterForValue( attributeName, value, java.sql.Date.class); return converter != null ? converter.convert(value) : Convert.toSqlDate(value); }
/** * Sets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute. * @param value value to convert. * @return reference to this model. */ public <T extends Model> T setDate(String attributeName, Object value) { Converter<Object, java.sql.Date> converter = modelRegistryLocal().converterForValue( attributeName, value, java.sql.Date.class); return setRaw(attributeName, converter != null ? converter.convert(value) : Convert.toSqlDate(value)); }
/** * Gets attribute value as <code>java.sql.Date</code>. * If there is a {@link Converter} registered for the attribute that converts from Class <code>S</code> to Class * <code>java.sql.Date</code>, given the attribute value is an instance of <code>S</code>, then it will be used, * otherwise performs a conversion using {@link Convert#toSqlDate(Object)}. * * @param attributeName name of attribute to convert * @return value converted to <code>java.sql.Date</code> */ public java.sql.Date getDate(String attributeName) { Object value = getRaw(attributeName); Converter<Object, java.sql.Date> converter = modelRegistryLocal().converterForValue( attributeName, value, java.sql.Date.class); return converter != null ? converter.convert(value) : Convert.toSqlDate(value); }