|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
public interface EntityEngine
Provides methods for working with the DB via Atlassian EntityEngine.
These methods are considered a higher level alternative to the OfBizDelegator and provide two main advantages:
Nested Class Summary | |
---|---|
static interface |
EntityEngine.SelectFromContext<E>
|
static interface |
EntityEngine.WhereContext<E>
|
static interface |
EntityEngine.WhereEqualAndContext<E>
|
static interface |
EntityEngine.WhereEqualContext<E>
|
Method Summary | ||
---|---|---|
|
createValue(EntityFactory<E> entityFactory,
E newValue)
|
|
int |
delete(Delete.DeleteWhereContext deleteContext)
Allows you to execute an SQL DELETE using a fluent interface. |
|
int |
execute(Update.WhereContext updateContext)
Allows you to execute an UPDATE statement using a fluent interface. |
|
|
removeValue(EntityFactory<E> entityFactory,
Long id)
Remove the given entity from the DB. |
|
|
selectFrom(EntityFactory<E> entityFactory)
Starts a dialog to run a SELECT query against EntityEngine. |
|
|
updateValue(EntityFactory<E> entityFactory,
E newValue)
|
Method Detail |
---|
<E> EntityEngine.SelectFromContext<E> selectFrom(EntityFactory<E> entityFactory)
e.g. to run "SELECT * FROM remotelink WHERE id = ?" (and return a single entity value) you could write:
RemoteIssueLink link = entityEngine.selectFrom(Entity.REMOTE_ISSUE_LINK) .whereEqual("id", remoteIssueLinkId) .singleValue();e.g. to run "SELECT * FROM remotelink WHERE issueid = ? AND app = ? ORDER BY type" you could write:
ListremoteIssueLinks = entityEngine.selectFrom(Entity.REMOTE_ISSUE_LINK) .whereEqual("issueid", issueId) .andEqual("app", app) .orderBy("type");
- Type Parameters:
E
- Entity Data Object type.- Parameters:
entityFactory
- that can convert GenericValues into Entity data objects. SeeEntity
for existing factories.- Returns:
- The context that begins a fluent dialog to run a SELECT query.
- See Also:
Entity
<E> E createValue(EntityFactory<E> entityFactory, E newValue)
<E> void updateValue(EntityFactory<E> entityFactory, E newValue)
<E> int removeValue(EntityFactory<E> entityFactory, Long id)
entityFactory
- represents the entity type (ie TABLE)id
- the id of the row to delete.
int execute(Update.WhereContext updateContext)
See the Update
class for an example.
updateContext
- build up a fluent UPDATE statement here. Should start with Update.into(
int delete(Delete.DeleteWhereContext deleteContext)
You should call this using code that looks like:
entityEngine.delete(Delete.from(Entity.ISSUE_SECURITY_LEVEL).whereIdEquals(securityLevelId));or:
entityEngine.delete( Delete.from(Entity.ISSUE_SECURITY_LEVEL) .whereEqual("scheme", schemeId) .andEqual("name", name) );
deleteContext
- build up a fluent DELETE statement here. Should start with Delete.from(
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |