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

2024-03-15 06:08

本文主要是介绍【工作流前进之路】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项目中遇见过,它可以说就是咱们的老相识了。多和以前的知识结合,你会发现以一切都很简单的。

这篇关于【工作流前进之路】Activiti数据查询排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/811032

相关文章

在Java中基于Geotools对PostGIS数据库的空间查询实践教程

《在Java中基于Geotools对PostGIS数据库的空间查询实践教程》本文将深入探讨这一实践,从连接配置到复杂空间查询操作,包括点查询、区域范围查询以及空间关系判断等,全方位展示如何在Java环... 目录前言一、相关技术背景介绍1、评价对象AOI2、数据处理流程二、对AOI空间范围查询实践1、空间查

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>