Class ResultSetIterator
- java.lang.Object
-
- org.apache.commons.beanutils.ResultSetIterator
-
public class ResultSetIterator extends java.lang.Object implements DynaBean, java.util.Iterator<DynaBean>
Implements
Iteratorreturned by theiterator()method ofResultSetDynaClass. Each object returned by this iterator will be aDynaBeanthat represents a single row from the result set being wrapped.
-
-
Field Summary
Fields Modifier and Type Field Description protected booleancurrentFlag indicating whether the result set is currently positioned at a row for which we have not yet returned an element in the iteration.protected ResultSetDynaClassdynaClassTheResultSetDynaClasswe are associated with.protected booleaneofFlag indicating whether the result set has indicated that there are no further rows.
-
Constructor Summary
Constructors Constructor Description ResultSetIterator(ResultSetDynaClass dynaClass)Construct anIteratorfor the result set being wrapped by the specifiedResultSetDynaClass.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidadvance()Advance the result set to the next row, if there is not a current row (and if we are not already at eof).booleancontains(java.lang.String name, java.lang.String key)Does the specified mapped property contain a value for the specified key value?java.lang.Objectget(java.lang.String name)Return the value of a simple property with the specified name.java.lang.Objectget(java.lang.String name, int index)Return the value of an indexed property with the specified name.java.lang.Objectget(java.lang.String name, java.lang.String key)Return the value of a mapped property with the specified name, ornullif there is no value for the specified key.DynaClassgetDynaClass()Return theDynaClassinstance that describes the set of properties available for this DynaBean.booleanhasNext()Returntrueif the iteration has more elements.DynaBeannext()Return the next element in the iteration.voidremove()Remove the current element from the iteration.voidremove(java.lang.String name, java.lang.String key)Remove any existing value for the specified key on the specified mapped property.voidset(java.lang.String name, int index, java.lang.Object value)Set the value of an indexed property with the specified name.voidset(java.lang.String name, java.lang.Object value)Set the value of a simple property with the specified name.voidset(java.lang.String name, java.lang.String key, java.lang.Object value)Set the value of a mapped property with the specified name.
-
-
-
Field Detail
-
current
protected boolean current
Flag indicating whether the result set is currently positioned at a row for which we have not yet returned an element in the iteration.
-
dynaClass
protected ResultSetDynaClass dynaClass
The
ResultSetDynaClasswe are associated with.
-
eof
protected boolean eof
Flag indicating whether the result set has indicated that there are no further rows.
-
-
Constructor Detail
-
ResultSetIterator
ResultSetIterator(ResultSetDynaClass dynaClass)
Construct an
Iteratorfor the result set being wrapped by the specifiedResultSetDynaClass.- Parameters:
dynaClass- TheResultSetDynaClasswrapping the result set we will iterate over
-
-
Method Detail
-
advance
protected void advance() throws java.sql.SQLExceptionAdvance the result set to the next row, if there is not a current row (and if we are not already at eof).
- Throws:
java.sql.SQLException- if the result set throws an exception
-
contains
public boolean contains(java.lang.String name, java.lang.String key)Does the specified mapped property contain a value for the specified key value?- Specified by:
containsin interfaceDynaBean- Parameters:
name- Name of the property to checkkey- Name of the key to check- Returns:
trueif the mapped property contains a value for the specified key, otherwisefalse- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified name
-
get
public java.lang.Object get(java.lang.String name)
Return the value of a simple property with the specified name.
-
get
public java.lang.Object get(java.lang.String name, int index)Return the value of an indexed property with the specified name.- Specified by:
getin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be retrievedindex- Index of the value to be retrieved- Returns:
- The indexed property's value
- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not indexedjava.lang.IndexOutOfBoundsException- if the specified index is outside the range of the underlying propertyjava.lang.NullPointerException- if no array or List has been initialized for this property
-
get
public java.lang.Object get(java.lang.String name, java.lang.String key)Return the value of a mapped property with the specified name, ornullif there is no value for the specified key.- Specified by:
getin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be retrievedkey- Key of the value to be retrieved- Returns:
- The mapped property's value
- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not mapped
-
getDynaClass
public DynaClass getDynaClass()
Return theDynaClassinstance that describes the set of properties available for this DynaBean.- Specified by:
getDynaClassin interfaceDynaBean- Returns:
- The associated DynaClass
-
hasNext
public boolean hasNext()
Return
trueif the iteration has more elements.- Specified by:
hasNextin interfacejava.util.Iterator<DynaBean>- Returns:
trueif the result set has another row, otherwisefalse
-
next
public DynaBean next()
Return the next element in the iteration.
- Specified by:
nextin interfacejava.util.Iterator<DynaBean>- Returns:
- advance to the new row and return this
-
remove
public void remove()
Remove the current element from the iteration. This method is not supported.
- Specified by:
removein interfacejava.util.Iterator<DynaBean>
-
remove
public void remove(java.lang.String name, java.lang.String key)Remove any existing value for the specified key on the specified mapped property.
-
set
public void set(java.lang.String name, int index, java.lang.Object value)Set the value of an indexed property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setindex- Index of the property to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not indexedjava.lang.IndexOutOfBoundsException- if the specified index is outside the range of the underlying property
-
set
public void set(java.lang.String name, java.lang.Object value)Set the value of a simple property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.NullPointerException- if an attempt is made to set a primitive property to null
-
set
public void set(java.lang.String name, java.lang.String key, java.lang.Object value)Set the value of a mapped property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setkey- Key of the property to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not mapped
-
-