Interface GenericQueryManager<BeanType>
- All Superinterfaces:
- ValidationContext
- All Known Implementing Classes:
- AbstractGenericQueryManager,- ContentQueryManager,- GenericQueryManagerDelegate
GenericQueryManager provides features that make it easy to
 persist and retrieve beans in a database with single method calls. An
 instance of the manager can be obtained by using the GenericQueryManagerFactory class.
 Callbacks are also supported to make it possible to interact with the
 persistence actions in a bean-centric way. More information can be found in
 the Callbacks interface.
- Since:
- 1.0
- See Also:
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddListener(GenericQueryManagerListener<BeanType> listener) Add the listener to the manager to get notifications when actions were successful.intcount()Count the number of beans persisted.intcount(CountQuery query) Count the number of beans persisted with a customCountQuery.<OtherBeanType>
 GenericQueryManager<OtherBeanType>createNewManager(Class<OtherBeanType> beanClass) Create a new generic query manager of the same kind but for another bean class.booleandelete(int objectId) Delete a single identified beanbooleandelete(DeleteQuery query) Delete beans selected by the passed inDeleteQueryGet the handled classGet the baseCountQueryused to count the number of beans persisted under this managerReturn the baseDeleteQuerythat would be used to delete beansgetDeleteQuery(int objectId) Return the baseDeleteQuerythat would be used to delete a single beanGet the name of the property defined as the identifier.intgetIdentifierValue(BeanType bean) Get the value of the property defined as the identifier.Get the query that would be used to install the table.Get the base query used to restore beans.getRestoreQuery(int objectId) Get the base query used to restore a single identified bean.getTable()Get the managed database table nameintInsert a bean in the database.voidinstall()Install the database structure into the database.voidinstall(CreateTable query) Install the database structure into the database using a custom query.voidremove()Remove the database structurevoidRemove all the listeners that are registered to the manager.restore()Restore all the beans persisted under this manager.restore(int objectId) Restore a single bean using the identifier.booleanrestore(DbRowProcessor rowProcessor) Restore all beans using the row processor provided.booleanrestore(BeanFetcher<BeanType> beanFetcher) Restore all beans using the bean fetcher provided.restore(RestoreQuery query) Restore a list of beans that match the providedRestoreQuery.booleanrestore(RestoreQuery query, DbRowProcessor rowProcessor) Restore a list of beans that match the providedRestoreQueryand process with theDbRowProcessor.booleanrestore(RestoreQuery query, BeanFetcher<BeanType> beanFetcher) Restore a list of beans that match the providedRestoreQueryand process with theBeanFetcher.restoreFirst(RestoreQuery query) Restore the first bean that matches theRestoreQuery.intPersist a bean.intUpdate an existing bean in the database.Methods inherited from interface rife.validation.ValidationContextvalidate
- 
Method Details- 
getBaseClassClass getBaseClass()Get the handled class- Returns:
- the handled class
- Since:
- 1.0
 
- 
getTableString getTable()Get the managed database table name- Returns:
- the table name
- Since:
- 1.0
 
- 
getIdentifierNameString getIdentifierName()Get the name of the property defined as the identifier.Defaults to "id". - Returns:
- the name of the property defined as the identifier
- Since:
- 1.0
 
- 
getIdentifierValueGet the value of the property defined as the identifier.The property defaults to "id". - Parameters:
- bean- the bean to retrieve the identifier value for
- Returns:
- the value of the property defined as the identifier
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
installInstall the database structure into the database.This method will cause the structure needed to persist the bean to be installed into the database. This includes any validatity checks that the database supports and that have already been defined. Including (but not limited to): length, notNull, notEmpty, etc. etc. This method will fail semi-gracefully if the installation fails. Generally it's best to catch the DatabaseExceptionand assume that the database is already installed.- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
installInstall the database structure into the database using a custom query.This method will cause the structure needed to persist the bean to be installed into the database using the provided custom query. The custom query is usually obtained by using getInstallTableQuery(). This includes any validatity checks that the database supports and that have already been defined. Including (but not limited to): length, notNull, notEmpty, etc. etc. This method will fail semi-gracefully if the installation fails. Generally it's best to catch theDatabaseExceptionand assume that the database is already installed.- Parameters:
- query- the- CreateTablequery to use to create the table
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
removeRemove the database structureThis method will cause the database structure to be removed from the database deleting all saved beans in the process. No new beans of this type can be persisted until the database structure is reinstalled. - Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
savePersist a bean.This method allows a person to persist a bean to a DB to be later restored. A bean to be persisted must have at least one integer identifier and one bean property both with accessors. If the identifier value is greater than or equal to 0, the bean is attempted to be updated first, if this fails (or the identifier is -1) the bean is assumed to be a new bean and a new sequential identifier is generated by the database. - Parameters:
- bean- the bean to be saved
- Returns:
- the identifier assigned to the new/updated bean
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
insertInsert a bean in the database.This method specifically forces insertion of the bean into the database. This method is only recommended for use when you know what you are doing. The save(Object bean)method is safer because it can detect whether to insert or update the bean in that database, leading to safer, simpler code. Bean restrictions mirrorsave(Object bean).- Parameters:
- bean- the bean to be inserted
- Returns:
- the identifier assigned to the new bean
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
updateUpdate an existing bean in the database.This method specifically forces the updating of the bean into the database. This method is only recommended for use when you know what you are doing. The save(Object bean)method is safer because it can detect whether to insert or update the bean in that database, leading to safer, simpler code. Bean restrictions mirrorsave(Object bean).- Parameters:
- bean- the bean to be updated
- Returns:
- the identifier assigned to the new bean
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
restoreRestore all the beans persisted under this manager.This method will return a Listof all the beans persisted under this manager.- Returns:
- a Listof all the persisted beans
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
restoreRestore a single bean using the identifier.This method will return a single bean having the provided identifier. Since the identifier is unique, you can be assured of a single bean with a persistent id. This id is never changed under normal circumstances. - Parameters:
- objectId- the identifier to identify the bean to restore
- Returns:
- the bean that matches the identifier provided
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
restoreRestore all beans using the row processor provided.This method will return all beans using a DbRowProcessorfor reduced memory requirements as opposed to the fullListversion ofrestore().- Parameters:
- rowProcessor- the DbRowProcessor each row should be passed to
- Returns:
- true if beans were restored, false if not
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
restoreRestore all beans using the bean fetcher provided.This method will return all beans using a BeanFetcherfor reduced memory requirements as opposed to the fullListversion ofrestore().- Parameters:
- beanFetcher- the RowProcessor each row should be passed to
- Returns:
- true if beans were restored, false if not
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
restoreFirstRestore the first bean that matches theRestoreQuery.This method will return the first bean that matches the RestoreQuery. Especially useful for selecting the first returned bean from a complex query.- Parameters:
- query- the query the bean should be restored from
- Returns:
- the first bean that matches the RestoreQuery
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
restoreRestore a list of beans that match the providedRestoreQuery.This method will return a list of beans that match the provided RestoreQuery. This can be used for more complex queries, or for exclusion of certain beans from the results.- Parameters:
- query- the query the beans should be restored from
- Returns:
- a list containing all the restored beans
- Throws:
- DatabaseException
- Since:
- 1.0
- See Also:
 
- 
restoreRestore a list of beans that match the providedRestoreQueryand process with theDbRowProcessor.This method will return a list of beans that match the provided RestoreQuery and process these matches with the provided DbRowProcessor. This can be used for more memory-intensive (or larger result sets) complex queries or for the exclusion of certain beans from the results.- Parameters:
- query- the query the beans should be restored from
- rowProcessor- the row processor that should be used to process each matched bean row
- Returns:
- true if beans were processed, false if not
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
restoreRestore a list of beans that match the providedRestoreQueryand process with theBeanFetcher.This method will return a list of beans that match the provided RestoreQuery and process these matches with the provided BeanFetcher. This can be used for more memory-intensive (or larger result sets) complex queries or for the exclusion of certain beans from the results.- Parameters:
- query- the query the beans should be restored from
- beanFetcher- the bean fetch that should be used to process each matched bean row
- Returns:
- true if beans were processed, false if not
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
getInstallTableQueryGet the query that would be used to install the table.This method will return the query that would be used to install the database structure. Can be used to modify the structure if i custom structure is needed. Mostly likely to be passed into install(CreateTable)- Returns:
- the query that would be used to install the database structure
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
getRestoreQueryRestoreQuery getRestoreQuery()Get the base query used to restore beans.This method will return the base query that would be used to restore beans with restore(). This can be used to restrict the query so that less beans are returned or certain beans are returned.- Returns:
- the query that would be used to restore a number of beans
- Since:
- 1.0
 
- 
getRestoreQueryGet the base query used to restore a single identified bean.This method will return the base query that would be used to restore a single bean with restore(int). This can be used to restrict the query so that a bean not matching the query will not be returned.- Returns:
- the query that would be used to restore a single identified bean
- Since:
- 1.0
 
- 
countCount the number of beans persisted.This method will count the total number of beans persisted under this manager. - Returns:
- the number of beans persisted under this manager
- Throws:
- DatabaseException
- Since:
- 1.0, 1.0
 
- 
countCount the number of beans persisted with a customCountQuery.This method will count the total number of beans persisted under this manager that match the provided CountQuery.- Parameters:
- query- the query that will be used to determine which beans to count
- Returns:
- the number of beans persisted under this manager that match the provided query
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
getCountQueryCountQuery getCountQuery()Get the baseCountQueryused to count the number of beans persisted under this manager- Returns:
- the query that would be used to count the total number of beans persisted under this managerù
- Since:
- 1.0
 
- 
deleteDelete a single identified beanThis method will delete the bean identifed by the passed in identifier. - Parameters:
- objectId- the identifier of the bean
- Returns:
- true if the deletion suceeded, false if it did not
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
deleteDelete beans selected by the passed inDeleteQueryThis method will delete all beans identified by the passed in DeleteQuery.- Parameters:
- query- the query to select the beans
- Returns:
- true if the deletion suceeded, false if it did not
- Throws:
- DatabaseException
- Since:
- 1.0
 
- 
getDeleteQueryDeleteQuery getDeleteQuery()Return the baseDeleteQuerythat would be used to delete beans- Returns:
- the base DeleteQuery
- Since:
- 1.0
 
- 
getDeleteQueryReturn the baseDeleteQuerythat would be used to delete a single bean- Parameters:
- objectId- the identifier to fill into the base- DeleteQuery
- Returns:
- the base DeleteQuery
- Since:
- 1.0
 
- 
addListenerAdd the listener to the manager to get notifications when actions were successful.- Parameters:
- listener- the listener that has to be added
- Since:
- 1.0
 
- 
removeListenersvoid removeListeners()Remove all the listeners that are registered to the manager.- Since:
- 1.0
 
- 
createNewManagerCreate a new generic query manager of the same kind but for another bean class.- Parameters:
- beanClass- the class of the bean for which the new generic query manager has to be created
- Returns:
- a new generic query manager instance
- Since:
- 1.0
 
 
-