【工作流前进之路】Activiti数据查询排序

     学习过SQL的人都知道,在数据库中运用Asc和Desc方法来进行排序,在工作流中,亦还是运用这两个方法来进行排序,因为工作流最终的还是需要和数据库进行交互.


     在我的前一篇博客<<【工作流前进之路】Activiti权限之用户组-数据查询>>中曾介绍到过一个借口叫做query,Query中也提供了Asc和Desc方法设置查询结果的排序方式,使用这两个方法的前提是必须告诉Query 对象是按照何种条件进行排序的.比如说常用的按照ID升序,按照Name降序.为了好理解,看看下面的例子:

<span style="font-family:FangSong_GB2312;font-size:18px;">/**
 * 利用Asc和Desc进行排序
 * 
 * @author huan
 * 
 */
public class Sort {
	public static void main(String[] args) {
		// 创建流程引擎
		ProcessEngine engine = ProcessEngines.getDefaultProcessEngine();
		// 得到身份服务组件实例
		IdentityService identityService = engine.getIdentityService();
		// 调用orderByGroupId和asc方法,结果按照ID升序排序
		System.out.println("asc 排序结果");
		List<Group> datas = identityService.createGroupQuery().orderByGroupId().<span style="color:#ff0000;"><strong>asc()</strong></span>.list();
		for(Group data:datas){
			System.out.println(data.getId() + "-----" + data.getName() +" ");
		}
		// 调用orderByGroupName 和desc 方法,结果按照Name降序排序
		System.out.println("desc 排序结果");
		datas = identityService.createGroupQuery().orderByGroupName().<span style="color:#ff0000;"><strong>desc()</strong></span>.list();
		for(Group data:datas){
			System.out.println(data.getId() + "-----" + data.getName() + " ");
		}
	}
}</span>
运行结果如下:

     对于排序的结果,很可能你会问,为什么会这种现象呢.产生这种现象的原因是由于ID_序列段数据类型是字符型,以我用的Mysql为例,如果字段类型Wie字符型,而实际存储的是数据的话,那么进行排序时,会将其看作字符型,因此会产生如下看似错乱的样子.


     在前面我们说了使用Asc或者Desc方法排序的时候,必须指明按照何种条件排序,如果为指明条件,就会抛出ActivitiException异常,异常信息如下:

Exception in thread "main" org.activiti.engine.ActivitiException: You should call any of the orderBy methods first before specifying a direction
at org.activiti.engine.impl.AbstractQuery.direction(AbstractQuery.java:86)
at org.activiti.engine.impl.AbstractQuery.asc(AbstractQuery.java:76)
at org.crazyit.activiti.Sort.main(Sort.java:25)

     

     在实际应用中,除了按照单个字段排序以外,还有可能需要按照多个字段进行排序,例如根据名称降序,根据ID升序.那么在调用Asc和Desc方法时就需要注意,Asc方法和Desc方法会更加Query实例中的orderproperty属性来决定排序的字段,然后调用Asc或Desc方法时,就会根据当前Query实例所持有的orderproperty属性来创建orderBy语句.具体实例如下:

<span style="font-family:FangSong_GB2312;font-size:18px;">/**
 * 多字段排序
 * @author huan
 *
 */
public class Sortmix {
	public static void main(String[] args) {
		//创建流程引擎
		ProcessEngine engine = ProcessEngines.getDefaultProcessEngine();
		//得到身份服务组件实例
		IdentityService identityService = engine.getIdentityService();
		//先按照id降序,名称升序排序
		System.out.println("ID降序排序");
		<span style="color:#ff0000;"><strong>List<Group> datas = identityService.createGroupQuery().orderByGroupId().desc().orderByGroupName().asc().list();</strong></span>
		for(Group data : datas){
			System.out.println(data.getId() + "-----" + data.getName() +" ");
			
		}
		System.out.println("\n名称降序排序");
		datas = identityService.createGroupQuery().orderByGroupId().asc().orderByGroupName().desc().list();
		for(Group data : datas){
			System.out.println(data.getId() + "-----" + data.getName() +" ");
			
		}
	}
}
</span>

运行结果:



     对于工作流的排序,其实咱们并不陌生,在SQL中遇见过,在VB,VB.NET,C#,JAVA项目中遇见过,它可以说就是咱们的老相识了。多和以前的知识结合,你会发现以一切都很简单的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 22
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

弯_弯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值