com.avaje.ebeaninternal.server.query.DefaultSqlRow Maven / Gradle / Ivy
package com.avaje.ebeaninternal.server.query;
import java.math.BigDecimal;
import java.sql.Date;
import java.sql.Timestamp;
import java.util.Collection;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Set;
import java.util.UUID;
import com.avaje.ebean.SqlQuery;
import com.avaje.ebean.SqlRow;
import com.avaje.ebeaninternal.server.core.BasicTypeConverter;
/**
* Used to return raw SQL query results.
*
* Refer to {@link SqlQuery} for examples.
*
*
* There are convenience methods such as getInteger(), getBigDecimal() etc. The
* reason for these methods is that the values put into this map often come
* straight from the JDBC resultSet. Depending on the JDBC driver it may put a
* different type into a given property. For example an Integer, BigDecimal,
* Double could all be put into a property depending on the JDBC driver used.
* These convenience methods automatically convert the value as required
* returning the type you expect.
*
*/
public class DefaultSqlRow implements SqlRow {
static final long serialVersionUID = -3120927797041336242L;
private final String dbTrueValue;
/**
* The underlying map of property data.
*/
private final Map map;
/**
* Create with an initialCapacity and loadFactor.
*
* The defaults of these are 16 and 0.75.
*
*
* Note that the Map will rehash the contents when the number of keys in
* this map reaches its threshold (initialCapacity * loadFactor).
*
*/
public DefaultSqlRow(int initialCapacity, float loadFactor, String dbTrueValue) {
this.map = new LinkedHashMap<>(initialCapacity, loadFactor);
this.dbTrueValue = dbTrueValue;
}
public Iterator keys() {
return map.keySet().iterator();
}
/**
* Keys internally always lower cased to take out differences in database dictionaries.
*/
private Object asKey(Object name) {
return ((String) name).toLowerCase();
}
public Object remove(Object name) {
return map.remove(asKey(name));
}
public Object get(Object name) {
return map.get(asKey(name));
}
public Object put(String name, Object value) {
return setInternal(name, value);
}
public Object set(String name, Object value) {
return setInternal(name, value);
}
private Object setInternal(String name, Object newValue) {
return map.put(name.toLowerCase(), newValue);
}
public UUID getUUID(String name) {
return BasicTypeConverter.toUUID(get(name));
}
public Boolean getBoolean(String name) {
return BasicTypeConverter.toBoolean(get(name), dbTrueValue);
}
public Integer getInteger(String name) {
return BasicTypeConverter.toInteger(get(name));
}
public BigDecimal getBigDecimal(String name) {
return BasicTypeConverter.toBigDecimal(get(name));
}
public Long getLong(String name) {
return BasicTypeConverter.toLong(get(name));
}
public Double getDouble(String name) {
return BasicTypeConverter.toDouble(get(name));
}
public Float getFloat(String name) {
return BasicTypeConverter.toFloat(get(name));
}
public String getString(String name) {
return BasicTypeConverter.toString(get(name));
}
public java.util.Date getUtilDate(String name) {
return BasicTypeConverter.toUtilDate(get(name));
}
public Date getDate(String name) {
return BasicTypeConverter.toDate(get(name));
}
public Timestamp getTimestamp(String name) {
return BasicTypeConverter.toTimestamp(get(name));
}
public String toString() {
return map.toString();
}
// ------------------------------------
// Normal map methods...
public void clear() {
map.clear();
}
public boolean containsKey(Object key) {
return map.containsKey(asKey(key));
}
public boolean containsValue(Object value) {
return map.containsValue(value);
}
public Set> entrySet() {
return map.entrySet();
}
public boolean isEmpty() {
return map.isEmpty();
}
public Set keySet() {
return map.keySet();
}
public void putAll(Map extends String, ?> t) {
map.putAll(t);
}
public int size() {
return map.size();
}
public Collection
© 2015 - 2025 Weber Informatics LLC | Privacy Policy