org.apache.dolphinscheduler.dao.mapper.TaskDefinitionMapper.xml Maven / Gradle / Ivy
<?xml version="1.0" encoding="UTF-8"?> <!-- ~ Licensed to the Apache Software Foundation (ASF) under one or more ~ contributor license agreements. See the NOTICE file distributed with ~ this work for additional information regarding copyright ownership. ~ The ASF licenses this file to You under the Apache License, Version 2.0 ~ (the "License"); you may not use this file except in compliance with ~ the License. You may obtain a copy of the License at ~ ~ http://www.apache.org/licenses/LICENSE-2.0 ~ ~ Unless required by applicable law or agreed to in writing, software ~ distributed under the License is distributed on an "AS IS" BASIS, ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ~ See the License for the specific language governing permissions and ~ limitations under the License. --> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="org.apache.dolphinscheduler.dao.mapper.TaskDefinitionMapper"> <sql id="baseSql"> id, code, name, version, description, project_code, user_id, task_type, task_params, flag, task_priority, worker_group, environment_code, fail_retry_times, fail_retry_interval, timeout_flag, timeout_notify_strategy, timeout, delay_time, resource_ids, create_time, update_time, task_group_id,task_group_priority </sql> <sql id="baseSqlV2"> ${alias}.id, ${alias}.code, ${alias}.name, ${alias}.version, ${alias}.description, ${alias}.project_code, ${alias}.user_id, ${alias}.task_type, ${alias}.task_params, ${alias}.flag, ${alias}.task_priority, ${alias}.worker_group, ${alias}.environment_code, ${alias}.fail_retry_times, ${alias}.fail_retry_interval, ${alias}.timeout_flag, ${alias}.timeout_notify_strategy, ${alias}.timeout, ${alias}.delay_time, ${alias}.resource_ids, ${alias}.create_time, ${alias}.update_time, ${alias}.task_group_id, ${alias}.task_group_priority </sql> <select id="queryByName" resultType="org.apache.dolphinscheduler.dao.entity.TaskDefinition"> select <include refid="baseSqlV2"> <property name="alias" value="td"/> </include> from t_ds_task_definition td join t_ds_process_task_relation ptr on ptr.project_code = td.project_code where td.project_code = #{projectCode} and td.name = #{name} and ptr.process_definition_code = #{processCode} and td.code = ptr.post_task_code limit 1 </select> <select id="queryAllDefinitionList" resultType="org.apache.dolphinscheduler.dao.entity.TaskDefinition"> select <include refid="baseSql"/> from t_ds_task_definition where project_code = #{projectCode} order by create_time desc </select> <select id="countDefinitionGroupByUser" resultType="org.apache.dolphinscheduler.dao.entity.DefinitionGroupByUser"> SELECT td.user_id as user_id, tu.user_name as user_name, count(0) as count FROM t_ds_task_definition td JOIN t_ds_user tu on tu.id=td.user_id where 1 = 1 <if test="projectCodes != null and projectCodes.length != 0"> and td.project_code in <foreach collection="projectCodes" index="index" item="i" open="(" separator="," close=")"> #{i} </foreach> </if> group by td.user_id,tu.user_name </select> <select id="queryByCode" resultType="org.apache.dolphinscheduler.dao.entity.TaskDefinition"> select <include refid="baseSql"/> from t_ds_task_definition where code = #{code} </select> <select id="listResources" resultType="java.util.HashMap"> SELECT id,resource_ids FROM t_ds_task_definition WHERE resource_ids is not null and resource_ids != '' </select> <select id="listResourcesByUser" resultType="java.util.HashMap"> SELECT id,resource_ids FROM t_ds_task_definition WHERE user_id = #{userId} and resource_ids is not null and resource_ids != '' </select> <delete id="deleteByCode"> delete from t_ds_task_definition where code = #{code} </delete> <insert id="batchInsert"> insert into t_ds_task_definition (code, name, version, description, project_code, user_id, task_type, task_params, flag, task_priority, worker_group, environment_code, fail_retry_times, fail_retry_interval, timeout_flag, timeout_notify_strategy, timeout, delay_time, resource_ids, create_time, update_time,task_group_id) values <foreach collection="taskDefinitions" item="taskDefinition" separator=","> (#{taskDefinition.code},#{taskDefinition.name},#{taskDefinition.version},#{taskDefinition.description}, #{taskDefinition.projectCode},#{taskDefinition.userId},#{taskDefinition.taskType},#{taskDefinition.taskParams},#{taskDefinition.flag}, #{taskDefinition.taskPriority},#{taskDefinition.workerGroup},#{taskDefinition.environmentCode},#{taskDefinition.failRetryTimes}, #{taskDefinition.failRetryInterval},#{taskDefinition.timeoutFlag},#{taskDefinition.timeoutNotifyStrategy},#{taskDefinition.timeout}, #{taskDefinition.delayTime},#{taskDefinition.resourceIds},#{taskDefinition.createTime},#{taskDefinition.updateTime}, #{taskDefinition.taskGroupId}) </foreach> </insert> <select id="queryDefineListPaging" resultType="org.apache.dolphinscheduler.dao.entity.TaskMainInfo"> select td.name task_name,td.code task_code,td.version task_version,td.task_type,td.create_time task_create_time,td.update_time task_update_time, pd.code process_definition_code,pd.version process_definition_version,pd.name process_definition_name,pd.release_state process_release_state, pt.pre_task_code upstream_task_code,up.name upstream_task_name from t_ds_task_definition td LEFT JOIN t_ds_process_task_relation pt ON td.code = pt.post_task_code and td.version=pt.post_task_version LEFT JOIN t_ds_process_definition pd ON pt.process_definition_code = pd.code and pt.process_definition_version=pd.version LEFT JOIN t_ds_task_definition up on pt.pre_task_code=up.code and pt.pre_task_version=up.version WHERE td.project_code = #{projectCode} <if test="taskType != ''"> and td.task_type = #{taskType} </if> <if test="searchWorkflowName != null and searchWorkflowName != ''"> and pd.name like concat('%', #{searchWorkflowName}, '%') </if> <if test="searchTaskName != null and searchTaskName != ''"> and td.name like concat('%', #{searchTaskName}, '%') </if> order by td.update_time desc </select> <select id="queryByCodeList" resultType="org.apache.dolphinscheduler.dao.entity.TaskDefinition"> select <include refid="baseSql"/> from t_ds_task_definition where 1 = 1 <if test="codes != null and codes.size != 0"> and code in <foreach collection="codes" index="index" item="i" open="(" separator="," close=")"> #{i} </foreach> </if> </select> </mapper>
© 2015 - 2025 Weber Informatics LLC | Privacy Policy