activiti5 使用自定义sql

最近在研究工作流activiti,把自己的开发过程做的验证发表出来给大家参考,说的并不会很全,但是都是自己验证可以使用的。

有时候在使用activiti提供的api不满足业务的时候使用自定义sql

两种:

1.xml配置:

<?xml version="1.0" encoding="UTF-8" ?>


<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="org.activiti.engine.impl.persistence.entity.HistoricProcessInstanceEntity">

 
  <select id="selectHistoricProcessInstanceIdsByProcessDefinitionId1" parameterType="org.activiti.engine.impl.db.ListQueryParameterObject" resultType="string">
    select ID_
    from ${prefix}ACT_HI_PROCINST 
    where PROC_DEF_ID_ = #{parameter}
  </select>
  

</mapper>

package com.newland.mango.rest.dao;

import java.io.InputStream;
import java.util.List;

import org.activiti.engine.impl.interceptor.Command;
import org.activiti.engine.impl.interceptor.CommandContext;

public class ProcessCmd  implements Command<List<String>> {

	@Override
	public List<String> execute(CommandContext commandContext) {
		List<String> processInstanceIds =commandContext.getDbSqlSession().selectList("selectHistoricProcessInstanceIdsByProcessDefinitionId1","cs:1:5004");
		// TODO Auto-generated method stub
		return processInstanceIds;
	}

}

  Set customMybatisXMLMappers = new HashSet();
   customMybatisXMLMappers.add("com/newland/mango/rest/dao/HistoricProcessInstance.xml");
   processEngineConfiguration.setCustomMybatisXMLMappers(customMybatisXMLMappers);
  

xml的配置使用mybatis,自己复制了enginejar的配置,改了id做个实验。

2.annotation配置:


public interface ProcessInstanceDao {
	  @Select({
	      "SELECT instance.proc_inst_id_ from act_hi_procinst instance,act_re_procdef definition ",
	      "where instance.proc_def_id_ =definition.id_"
	  })
	  List<Map<String, Object>> selectTaskWithSpecificVariable(String variableName);
}

 Set<Class<?>> set = new HashSet<Class<?>>();
   set.add(ProcessInstanceDao.class);
   processEngineConfiguration.setCustomMybatisMappers(set);

 List<Map<String,Object>> result = managementService.executeCustomSql(customSqlExecution);
  System.out.println("1111111111111:"+result.size());
  List processInstanceIds =managementService.executeCommand(new ProcessCmd());
  System.out.println("222222222:"+processInstanceIds.size());
  Model model = repositoryService.getModel(modelId);

两种都可以,我更推荐第一种,其实如果是查询,可以使用各种service提供的本地查询,可以直接定义sql。

转载于:https://my.oschina.net/u/1261308/blog/490384

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值