在ACM中使用QuerySpec进行联合查询的示例

这篇博客展示了如何在ACM系统中利用QuerySpec构造联合查询,包括设置返回类、关联类、不查询子类、设置等价条件以及附加多个查询条件。详细步骤包括根据过程ID、角色、指派者引用键和业务对象引用进行筛选,并进行排序操作。
    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);
    }

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值