flowable使用taskService.addComment新增评论需要full_msg字段进行读取

背景

在构建创业项目JeecgFlow过程中,在调用taskService.addComment接口出现了异常。就是数据存储的Message信息出现了截取,也就是存储不完整。 效果如下.


flowable版本=6.7.2

问题排查

  • 接口详解及问题代码

    //新增评论的接口说明
    Comment addComment(String taskId,String processInstanceId,String message)
    //出问题的代码
    CommentHistoryRes.CommentDTO commentDTO = new CommentHistoryRes.CommentDTO();
    commentDTO.setComment(userTaskRejectReq.getComment());
    commentDTO.setImageUrl(userTaskRejectReq.getImageUrl());
    commentDTO.setTaskStatus("驳回");
    taskService.addComment(userTaskRejectReq.getTaskId(),userTaskRejectReq.getProcessInstanceId(), JSON.toJSONString(commentDTO));

  • 数据库字段Message的长短的排查

    CREATE TABLE act_hi_comment (
    ID_ varchar(64) COLLATE utf8_bin NOT NULL,
    TYPE_ varchar(255) COLLATE utf8_bin DEFAULT NULL,
    TIME_ datetime(3) NOT NULL,
    USER_ID_ varchar(255) COLLATE utf8_bin DEFAULT NULL,
    TASK_ID_ varchar(64) COLLATE utf8_bin DEFAULT NULL,
    PROC_INST_ID_ varchar(64) COLLATE utf8_bin DEFAULT NULL,
    ACTION_ varchar(255) COLLATE utf8_bin DEFAULT NULL,
    MESSAGE_ varchar(4000) COLLATE utf8_bin DEFAULT NULL,
    FULL_MSG_ longblob,
    PRIMARY KEY (ID_)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

MESSAGE_字段4000, 完全满足我的业务需求啊。应该不是这个原因。

  • 错误的原因

    1.TaskService.addComment是新增操作, saveComment是修改操作。
    2.addComment应该在操作流程之前,例如用户任务节点审批,先进行addComment操作,然后complete完成
    3.comment表中,有两个字段message, full_message。message字段存储前163个字段内容。fullMessage完整的审批信息。因此获取审批内容是取fullMessage而不是message字段。

此获取审批内容是取fullMessage而不是message字段。

解决办法,因为我是一次性查询多个task的comment。因此直接走了表查询,采用jdbcTemplate,并且fullMessage使用string字段类型接收.

复制代码
String ids = taskIdList.stream().map(m -> "'" + m + "'").collect(Collectors.joining(","));
sql.append("select hc.ID_ as id, hc.PROC_INST_ID_ as procInstID, hc.TASK_ID_ as taskId, hc.MESSAGE_ as message, hc.FULL_MESSAGE_ as fullMessage ");
sql.append("from act_hi_comment hc where hc.TASK_ID_ in (" + ids + ")");
List<Map<String, Object>> resultList = jdbcTemplate.queryForList(sql.toString());

如果是单个task任务,可以用api

复制代码
taskService.getTaskComments(taskId)

更多关于工作流知识,请访问: www.jeecgflow.com

相关推荐
特立独行的猫a13 小时前
告别写作焦虑:用 n8n + AI 打造“输入即发布”的自驱动写作工作流
人工智能·工作流·n8n
一马平川的大草原17 小时前
dify的知识库如何通过API调用操作
知识库·工作流·dify
hhzz9 天前
Activiti Modeling Application 7.9.0 详细介绍与快速部署清单
activiti7·工作流引擎·工作流·jav
程序员柒叔10 天前
Dify 集成-向量数据库
数据库·milvus·向量数据库·工作流·dify·向量库
摘星编程11 天前
【TextIn大模型加速器 + 火山引擎】用Coze+TextIn+飞书搭建智能合同审查工作流
火山引擎·工作流·coze·textin
todoitbo11 天前
【TextIn大模型加速器 + 火山引擎】基于 Dify 构建企业智能文档中枢:技术文档问答+合同智审+发票核验一站式解决方案
人工智能·ocr·火山引擎·工作流·dify·textln·企业智能文档
Lethehong12 天前
统一解析 × 大模型生成:多平台热点内容自动化总结工作流实战
工作流·dify·蓝耘元生代·蓝耘maas
小楼v13 天前
构建高效AI工作流:Java生态的LangGraph4j框架详解
java·后端·工作流·langgraph4j
装不满的克莱因瓶14 天前
【Coze智能体实战二】一键生成儿歌背单词视频
人工智能·ai·实战·agent·工作流·智能体·coze
2022.11.7始学前端15 天前
Dify第二节:AI 出题助手并写入飞书云文档
算法·工作流·dify