|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.apache.commons.dbutils.handlers.KeyedHandler
ResultSetHandler
implementation that returns a Map of Maps.
ResultSet
rows are converted into Maps which are then stored
in a Map under the given key. Although this implementation uses Maps to
store row contents, subclasses are encouraged to override the
createRow()
method to convert the rows into any kind of object.
If you had a Person table with a primary key column called ID, you could retrieve rows from the table like this:
ResultSetHandler h = new KeyedHandler("id"); Map found = (Map) queryRunner.query("select id, name, age from person", h); Map jane = (Map) found.get(new Long(1)); // jane's id is 1 String janesName = (String) jane.get("name"); Integer janesAge = (Integer) jane.get("age");Note that the "id" passed to KeyedHandler and "name" and "age" passed to the returned Map's get() method can be in any case. The data types returned for name and age are dependent upon how your JDBC driver converts SQL column types from the Person table into Java types.
To avoid these type issues you could subclass KeyedHandler and override
createRow()
to store rows in Java bean instances (ie. a
Person class).
This class is thread safe.
ResultSetHandler
Field Summary | |
protected int |
columnIndex
The column index to retrieve key values from. |
protected java.lang.String |
columnName
The column name to retrieve key values from. |
protected RowProcessor |
convert
The RowProcessor implementation to use when converting rows into Objects. |
Constructor Summary | |
KeyedHandler()
Creates a new instance of KeyedHandler. |
|
KeyedHandler(int columnIndex)
Creates a new instance of KeyedHandler. |
|
KeyedHandler(RowProcessor convert)
Creates a new instance of KeyedHandler. |
|
KeyedHandler(java.lang.String columnName)
Creates a new instance of KeyedHandler. |
Method Summary | |
protected java.lang.Object |
createKey(java.sql.ResultSet rs)
This factory method is called by handle() to retrieve the
key value from the current ResultSet row. |
protected java.util.Map |
createMap()
This factory method is called by handle() to create the Map
to store records in. |
protected java.lang.Object |
createRow(java.sql.ResultSet rs)
This factory method is called by handle() to store the
current ResultSet row in some object. |
java.lang.Object |
handle(java.sql.ResultSet rs)
Convert each row's columns into a Map and store then in a Map under ResultSet.getObject(key) key. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
protected RowProcessor convert
protected int columnIndex
protected java.lang.String columnName
Constructor Detail |
public KeyedHandler()
public KeyedHandler(RowProcessor convert)
convert
- The RowProcessor
implementation
to use when converting rows into Mapspublic KeyedHandler(int columnIndex)
columnIndex
- The values to use as keys in the Map are
retrieved from the column at this index.public KeyedHandler(java.lang.String columnName)
columnName
- The values to use as keys in the Map are
retrieved from the column with this name.Method Detail |
public java.lang.Object handle(java.sql.ResultSet rs) throws java.sql.SQLException
Map
under ResultSet.getObject(key)
key.
handle
in interface ResultSetHandler
rs
- The ResultSet
to handle. It has not been touched
before being passed to this method.
Map
of Maps, never null
.
java.sql.SQLException
- if a database access error occursResultSetHandler.handle(java.sql.ResultSet)
protected java.util.Map createMap()
handle()
to create the Map
to store records in. This implementation returns a HashMap
instance.
protected java.lang.Object createKey(java.sql.ResultSet rs) throws java.sql.SQLException
handle()
to retrieve the
key value from the current ResultSet
row. This
implementation returns ResultSet.getObject()
for the
configured key column name or index.
rs
- ResultSet to create a key from
java.sql.SQLException
- if a database access error occursprotected java.lang.Object createRow(java.sql.ResultSet rs) throws java.sql.SQLException
handle()
to store the
current ResultSet
row in some object. This
implementation returns a Map
with case insensitive column
names as keys. Calls to map.get("COL")
and
map.get("col")
return the same value.
rs
- ResultSet to create a row from
java.sql.SQLException
- if a database access error occurs
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |