All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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 t) { map.putAll(t); } public int size() { return map.size(); } public Collection values() { return map.values(); } }