public void query(long processId, Role role, ObjectIdentifier assigneeRefKey, ObjectReference businessObjReference)
throws Exception {
// 构造一个查询对象QuerySpec
QuerySpec qs = new QuerySpec();
// 设置返回集Class
int i = qs.appendClassList(WfVotingEventAudit.class, true);
// 设置关联的Class
int j = qs.appendClassList(WfProcess.class, false);
// 不查询子类?
qs.setDescendantQuery(false);
// 设置联合查询的等价条件
qs.appendWhere(new SearchCondition(WfVotingEventAudit.class, "processKey", WfProcess.class, "key"), i, j);
// 附加条件1: id是long型
if (processId != 0) {
qs.appendAnd();
qs.appendWhere(
new SearchCondition(WfProcess.class, "thePersistInfo.theObjectIdentifier.id", "=", processId), j);
}
// 附加条件2: role是枚举型
if (role != null) {
qs.appendAnd();
qs.appendWhere(new SearchCondition(WfVotingEventAudit.class, "role", "=", role), i);
}
// 附加条件3: key是ObjectIdentifier对象
if (assigneeRefKey != null) {
qs.appendAnd();
qs.appendWhere(new SearchCondition(WfVotingEventAudit.class, "assigneeRef.key", "=", assigneeRefKey), i);
}
// 附加条件4: str是ObjectReference代表的字符串
if (businessObjReference != null) {
qs.appendAnd();
String str = new ReferenceFactory().getReferenceString(businessObjReference);
qs.appendWhere(new SearchCondition(WfProcess.class, "businessObjReference", "=", str), j);
}
// 不查询子集合?
qs.setQuerySet(false);
// 设置排序条件,true是降序,false是升序
qs.appendOrderBy(WfVotingEventAudit.class, "thePersistInfo.modifyStamp", true);
// 查询方法
QueryResult localQueryResult = PersistenceHelper.manager.find(qs);
}在ACM中使用QuerySpec进行联合查询的示例
最新推荐文章于 2024-10-16 18:11:51 发布
这篇博客展示了如何在ACM系统中利用QuerySpec构造联合查询,包括设置返回类、关联类、不查询子类、设置等价条件以及附加多个查询条件。详细步骤包括根据过程ID、角色、指派者引用键和业务对象引用进行筛选,并进行排序操作。
7073

被折叠的 条评论
为什么被折叠?



