All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.dolphinscheduler.dao.mapper.ProcessDefinitionMapper.xml Maven / Gradle / Ivy

There is a newer version: 3.2.1
Show newest version
<?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.ProcessDefinitionMapper">
    <sql id="baseSql">
        id, code, name, version, release_state, project_code, user_id, description,
        global_params, flag, locations, warning_group_id, create_time, timeout, tenant_id, update_time,execution_type
    </sql>

    <select id="verifyByDefineName" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select pd.id, pd.code, pd.name, pd.version, pd.release_state, pd.project_code, pd.user_id, pd.description,
        pd.global_params, pd.flag, pd.locations, pd.warning_group_id, pd.create_time, pd.timeout, pd.tenant_id, pd.update_time,pd.execution_type
        from t_ds_process_definition pd
        WHERE pd.project_code = #{projectCode}
        and pd.name = #{processDefinitionName}
    </select>

    <delete id="deleteByCode">
        delete from t_ds_process_definition
        where code = #{code}
    </delete>

    <select id="queryByCode" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select
        <include refid="baseSql"/>
        from t_ds_process_definition
        where code = #{code}
    </select>
    <select id="queryByCodes" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select
        <include refid="baseSql"/>
        from t_ds_process_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>

    <select id="queryByDefineName" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select pd.id, pd.code, pd.name, pd.version, pd.release_state, pd.project_code, p.id as project_id, pd.user_id, pd.description,
        pd.global_params, pd.flag, pd.locations, pd.warning_group_id, pd.create_time, pd.timeout, pd.tenant_id, pd.update_time,
        u.user_name,p.name as project_name,t.tenant_code,q.queue,q.queue_name,pd.execution_type
        from t_ds_process_definition pd
        JOIN t_ds_user u ON pd.user_id = u.id
        JOIN  t_ds_project p ON pd.project_code = p.code
        JOIN  t_ds_tenant t ON t.id = u.tenant_id
        JOIN t_ds_queue q ON t.queue_id = q.id
        WHERE p.code = #{projectCode}
        and pd.name = #{processDefinitionName}
    </select>
    <select id="queryDefineListPaging" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        SELECT td.id, td.code, td.name, td.version, td.release_state, td.project_code, td.user_id, td.description,
        td.global_params, td.flag, td.warning_group_id, td.timeout, td.tenant_id, td.update_time, td.create_time,
        sc.schedule_release_state, tu.user_name ,td.execution_type
        FROM t_ds_process_definition td
        left join (select process_definition_code,release_state as schedule_release_state from t_ds_schedules group by
        process_definition_code,release_state) sc on sc.process_definition_code = td.code
        left join t_ds_user tu on td.user_id = tu.id
        where td.project_code = #{projectCode}
        <if test=" searchVal != null and searchVal != ''">
            AND (td.name like concat('%', #{searchVal}, '%')
            OR td.description like concat('%', #{searchVal}, '%')
            )
        </if>
        <if test=" userId != 0">
            and td.user_id = #{userId}
        </if>
        order by sc.schedule_release_state desc,td.update_time desc,td.id asc
    </select>

    <select id="queryAllDefinitionList" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select
        <include refid="baseSql"/>
        from t_ds_process_definition
        where project_code = #{projectCode}
        order by create_time desc
    </select>
    <select id="queryDefinitionListByProjectCodeAndProcessDefinitionCodes" resultType="org.apache.dolphinscheduler.dao.entity.DependentSimplifyDefinition">
        select
            code, name, version
        from t_ds_process_definition
        where 1=1
        AND project_code = #{projectCode}
        <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>
    <select id="queryDefinitionListByTenant" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select
        <include refid="baseSql"/>
        from t_ds_process_definition
        where tenant_id = #{tenantId}
    </select>
    <select id="queryDefinitionListByIdList" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        select
        <include refid="baseSql"/>
        from t_ds_process_definition
        where id in
        <foreach collection="ids" index="index" item="i" open="(" separator="," close=")">
            #{i}
        </foreach>
    </select>
    <select id="countDefinitionByProjectCodes" 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_process_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="queryByDefineId" resultType="org.apache.dolphinscheduler.dao.entity.ProcessDefinition">
        SELECT
            pd.id, pd.code, pd.name, pd.version, pd.release_state, pd.project_code, pd.user_id, pd.description,
            pd.global_params, pd.flag, pd.locations, pd.warning_group_id, pd.create_time, pd.timeout,
            pd.tenant_id, pd.update_time, u.user_name,p.name AS project_name ,pd.execution_type
        FROM
            t_ds_process_definition pd,
            t_ds_user u,
            t_ds_project p
        WHERE
            pd.user_id = u.id AND pd.project_code = p.code
        AND pd.id = #{processDefineId}
    </select>

    <select id="listResources" resultType="java.util.HashMap">
        SELECT distinct pd.code,td.resource_ids
        FROM t_ds_process_task_relation ptr
        join t_ds_process_definition pd
            on ptr.process_definition_code=pd.code and ptr.process_definition_version = pd.version
                and ptr.project_code=pd.project_code and  pd.release_state = 1
        join t_ds_task_definition td
            on (ptr.pre_task_code=td.code and ptr.pre_task_version=td.version)
                or  (ptr.post_task_code=td.code and ptr.post_task_version=td.version)
        WHERE  td.resource_ids is not null and td.resource_ids != ''
    </select>

    <select id="listResourcesByUser" resultType="java.util.HashMap">
        SELECT distinct pd.code,td.resource_ids
        FROM t_ds_process_task_relation ptr
        join t_ds_process_definition pd
            on ptr.process_definition_code=pd.code and ptr.process_definition_version = pd.version
                and ptr.project_code=pd.project_code and  pd.release_state = 1
        join t_ds_task_definition td
            on (ptr.pre_task_code=td.code and ptr.pre_task_version=td.version)
                or  (ptr.post_task_code=td.code and ptr.post_task_version=td.version)
        WHERE  td.resource_ids is not null and td.resource_ids != '' and  td.user_id = #{userId}
    </select>

    <select id="listProjectIds" resultType="java.lang.Integer">
        SELECT DISTINCT(id) as project_id
        FROM t_ds_project
    </select>
</mapper>




© 2015 - 2025 Weber Informatics LLC | Privacy Policy