|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.torque.oid.IDBroker
public class IDBroker
This method of ID generation is used to ensure that code is
more database independent. For example, MySQL has an auto-increment
feature while Oracle uses sequences. It caches several ids to
avoid needing a Connection for every request.
This class uses the table ID_TABLE defined in
conf/master/id-table-schema.xml. The columns in ID_TABLE are used as
follows:
ID_TABLE_ID - The PK for this row (any unique int).
TABLE_NAME - The name of the table you want ids for.
NEXT_ID - The next id returned by IDBroker when it queries the
database (not when it returns an id from memory).
QUANTITY - The number of ids that IDBroker will cache in memory.
Use this class like this:
int id = dbMap.getIDBroker().getNextIdAsInt(null, "TABLE_NAME"); - or - BigDecimal[] ids = ((IDBroker)dbMap.getIDBroker()) .getNextIds("TABLE_NAME", numOfIdsToReturn);NOTE: When the ID_TABLE must be updated we must ensure that IDBroker objects running in different JVMs do not overwrite each other. This is accomplished using using the transactional support occuring in some databases. Using this class with a database that does not support transactions should be limited to a single JVM.
Field Summary | |
---|---|
static String |
COL_NEXT_ID
Next_ID column name |
static String |
COL_QUANTITY
Quantity column name |
static String |
COL_TABLE_ID
ID column name |
static String |
COL_TABLE_NAME
Table_Name column name |
static String |
ID_TABLE
Name of the ID_TABLE = ID_TABLE |
static String |
NEXT_ID
Fully qualified Next_ID column name |
static String |
QUANTITY
Fully qualified Quantity column name |
static String |
TABLE_ID
Fully qualified ID column name |
static String |
TABLE_NAME
Fully qualified Table_Name column name |
Constructor Summary | |
---|---|
IDBroker(Database database)
Constructs an IdBroker for the given Database. |
Method Summary | |
---|---|
boolean |
exists(String tableName)
|
BigDecimal |
getIdAsBigDecimal(Connection connection,
Object tableName)
Returns an id as a BigDecimal. |
int |
getIdAsInt(Connection connection,
Object tableName)
Returns an id as a primitive int. |
long |
getIdAsLong(Connection connection,
Object tableName)
Returns an id as a primitive long. |
String |
getIdAsString(Connection connection,
Object tableName)
Returns an id as a String. |
BigDecimal[] |
getNextIds(String tableName,
int numOfIdsToReturn)
This method returns x number of ids for the given table. |
BigDecimal[] |
getNextIds(String tableName,
int numOfIdsToReturn,
Connection connection)
This method returns x number of ids for the given table. |
protected BigDecimal |
getQuantity(String tableName)
Returns the quantity value for a table. |
boolean |
isConnectionRequired()
A flag to determine whether a Connection is required to generate an id. |
boolean |
isPostInsert()
A flag to determine the timing of the id generation |
boolean |
isPriorToInsert()
A flag to determine the timing of the id generation * |
boolean |
isThreadRunning()
Returns whether the idbroker thread is running. |
void |
run()
A background thread that tries to ensure that when someone asks for ids, that there are already some loaded and that the database is not accessed. |
void |
setConfiguration(org.apache.commons.configuration.Configuration configuration)
Set the configuration |
void |
start()
Starts the idBroker. |
void |
stop()
Shuts down the IDBroker thread. |
protected void |
updateQuantity(Connection con,
String tableName,
BigDecimal quantity)
Helper method to update a row in the ID_TABLE. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String ID_TABLE
public static final String COL_TABLE_NAME
public static final String TABLE_NAME
public static final String COL_TABLE_ID
public static final String TABLE_ID
public static final String COL_NEXT_ID
public static final String NEXT_ID
public static final String COL_QUANTITY
public static final String QUANTITY
Constructor Detail |
---|
public IDBroker(Database database)
database
- the database where this IdBroker is running in.Method Detail |
---|
public void start()
public void setConfiguration(org.apache.commons.configuration.Configuration configuration)
configuration
- the configurationpublic int getIdAsInt(Connection connection, Object tableName) throws TorqueException
getIdAsInt
in interface IdGenerator
connection
- A Connection.tableName
- an Object that contains additional info.
Exception
- Database error.
TorqueException
- if a Database error occurs.public long getIdAsLong(Connection connection, Object tableName) throws TorqueException
getIdAsLong
in interface IdGenerator
connection
- A Connection.tableName
- a String that identifies a table.
Exception
- Database error.
TorqueException
- if a Database error occurs.public BigDecimal getIdAsBigDecimal(Connection connection, Object tableName) throws TorqueException
getIdAsBigDecimal
in interface IdGenerator
connection
- A Connection.tableName
- a String that identifies a table..
Exception
- Database error.
TorqueException
- if a Database error occurs.public String getIdAsString(Connection connection, Object tableName) throws TorqueException
getIdAsString
in interface IdGenerator
connection
- A Connection should be null.tableName
- a String that identifies a table.
Exception
- Database error.
TorqueException
- if a Database error occurs.public boolean isPriorToInsert()
isPriorToInsert
in interface IdGenerator
boolean
valuepublic boolean isPostInsert()
isPostInsert
in interface IdGenerator
boolean
valuepublic boolean isConnectionRequired()
isConnectionRequired
in interface IdGenerator
boolean
valuepublic boolean isThreadRunning()
public BigDecimal[] getNextIds(String tableName, int numOfIdsToReturn) throws Exception
tableName
- The name of the table for which we want an id.numOfIdsToReturn
- The desired number of ids.
Exception
- Database error.public BigDecimal[] getNextIds(String tableName, int numOfIdsToReturn, Connection connection) throws TorqueException
tableName
- The name of the table for which we want an id.numOfIdsToReturn
- The desired number of ids.connection
- A Connection.
TorqueException
- on a database error.public boolean exists(String tableName) throws Exception
tableName
- a String
value that is used to identify
the row
boolean
value
TorqueException
- if a Torque error occurs.
Exception
- if another error occurs.public void run()
run
in interface Runnable
public void stop()
protected void updateQuantity(Connection con, String tableName, BigDecimal quantity) throws TorqueException
con
- A Connection.tableName
- The properly escaped name of the table to identify the
row.quantity
- An int with the value of the quantity.
TorqueException
- Database error.protected BigDecimal getQuantity(String tableName)
tableName
- the name of the table.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |