【工作流前进之路】Activiti 权限之用户组-数据查询

2024-03-15 06:08

本文主要是介绍【工作流前进之路】Activiti 权限之用户组-数据查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    用户组这个概念在权限系统中,出现的频率可以说是最高的,在百度百科中,对用户组的定义是这样的:在整个网路中,各个访问网络的用户的权限可能是各不相同的,可用将相同权限的用户划分为一组. 使用用户组管理,可以减少网络管理员的负担.

     用户组作为流程中的基础数据,Activiti提供了一套控制用户组的API,通过这些API可以对流程的基础数据进行管理.Activiti中用户组对应的表为ACT_ID_GROUP,对应的对象是Group对象,GroupActiviti对外提供的一个接口,一个Group实例表示一条用户组数据.Group接口只提供了相应字段的getset方法,ActivitiGroup有一个实现类GroupEntity,与对象映射关系,普遍应用于各个ORM框架中.

.创建用户组

IdentityService 提供saveGroup方法,Group 数据保存到数据库中.具体代码如下:

/*** 保存用户组* @author huan**/
@SuppressWarnings("unused")
public classSaveGroup {
// 将用户组数据保存到数据库中publicstatic void createGroup(IdentityService identityService, String id,
Stringname, String type) {
// 调用newGroup方法创建Group实例
Groupgroup = identityService.newGroup(id);
group.setName(name);
group.setType(type);
identityService.saveGroup(group);
}
}


 

.List方法

    Query 接口list方法将查询对象应用的实体数据已集合形式返回,对返回的集合需要指定元素类型,如果没有查询条件,则会将表中全部的数据查出,默认按照主键升序排序.

/*** list方法,封装查询结果,返回相应类型的集合* @author huan**/
public classListData {
publicstatic void main(String[] args) {//创建流程引擎
ProcessEngineengine = ProcessEngines.getDefaultProcessEngine();//得到身份服务组件实例
IdentityServiceidentityService = engine.getIdentityService();
//写入5条用户组数据
SaveGroup.createGroup(identityService,"1","userA","typeA");
SaveGroup.createGroup(identityService,"2","userB","typeB");
SaveGroup.createGroup(identityService,"3","userC","typeC");
SaveGroup.createGroup(identityService,"4","userD","typeD");
SaveGroup.createGroup(identityService,"5","userE","typeE");
//使用List方法查询全部的部署数据
List<Group>datas=identityService.createGroupQuery().list();
for(Groupdata:datas){
System.out.println(data.getId()+"-----"+data.getName()+"");
}}}
保存到数据库中的数据如下:


.listpage 方法

listpage方法和list 方法效果相似,唯一不同的就是listpage把查询结果分页了.

/*** listPage 处理查询数据分页问题* @author huan**/
public classlistPage {
publicstatic void main(String[] args) {
// 创建工作流引擎
ProcessEngineengine = ProcessEngines.getDefaultProcessEngine();
// 得到身份服务组件实现
IdentityServiceidentityService = engine.getIdentityService();
// 调用ListPage方法,从索引为3的记录开始,查询2条记录
List<Group>datas = identityService.createGroupQuery().listPage(3, 2);
for(Groupdata:datas){
System.out.println(data.getId()+ "------" + data.getName() + " ");
}
}
}


.count方法

该方法用于计算查询结果的数据量,类似SQL 中的select count语句.

/*** count ,计算查询结果的数据量* @author huan**/
public class count {
publicstatic void main(String[] args) {
//创建流程引擎
ProcessEngineengine=ProcessEngines.getDefaultProcessEngine();
//扥到身份服务组件实例
IdentityService  identityService=engine.getIdentityService();
//使用list方法查询全部的部署数据
longcountSize=identityService.createGroupQuery().count();
System.out.println(countSize);
}
}


五总结

    从代码中我们可以看出,不管是保存还是查询,查询用的是list,listpage 还是count ,这些都和我们学习ORM框架中的方法是一致的,学习是融会贯通的.

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



http://www.chinasem.cn/article/811030

相关文章

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate