Add missing data

  • CREATE TABLE #Template

    (

    TaskName VARCHAR(20),

    TemplateName VARCHAR(20)

    )

    INSERT INTO #Template ( TaskName,TemplateName)

    SELECT 'Task1', 'Template 1' UNION ALL

    SELECT 'Task2', 'Template 1' UNION ALL

    SELECT 'Task3', 'Template 1' UNION ALL

    SELECT 'Task4', 'Template 1'

    SELECT * FROM #Template

    CREATE TABLE #TasksByPlan

    (

    TaskName VARCHAR(20),

    TemplateName VARCHAR(20),

    PlanName VARCHAR(20)

    )

    INSERT INTO #TasksByPlan ( TaskName,TemplateName,PlanName)

    SELECT 'Task1', 'Template 1' ,'Plan1'UNION ALL

    SELECT 'Task2', 'Template 1','Plan1' UNION ALL

    SELECT 'Task3', 'Template 1','Plan1' UNION ALL

    SELECT 'Task1', 'Template 1','Plan2' UNION ALL

    SELECT 'Task2', 'Template 1','Plan2' UNION ALL

    SELECT 'Task3', 'Template 1','Plan2' UNION ALL

    SELECT 'Task4', 'Template 1','Plan2' UNION ALL

    SELECT 'Task1', 'Template 1','Plan3' UNION ALL

    SELECT 'Task2', 'Template 1','Plan3'

    SELECT * FROM #TasksByPlan

    I want to add missing tasks per plan from the #Template table . Any tasks that are missing for each plan should be added to #TasksByPlan table .

    I will have to add the following missing tasks to #TasksByPlan

    SELECT 'Task4', 'Template 1','Plan1'

    SELECT 'Task3', 'Template 1','Plan3'

    SELECT 'Task4', 'Template 1','Plan3'

    Please help .

    Thanks,
    PSB

  • Here is one way
    WITH AllPlans
    AS
    (
      SELECT DISTINCT
        tbp.PlanName
      FROM #TasksByPlan tbp
    )
    INSERT #TasksByPlan
    (
      TaskName
    , TemplateName
    , PlanName
    )
    SELECT
        t.TaskName
    ,    t.TemplateName
    ,    AllPlans.PlanName
    FROM
        #Template t
    CROSS JOIN AllPlans
    EXCEPT
    (SELECT
      tbp.TaskName
    ,  tbp.TemplateName
    ,  tbp.PlanName
    FROM #TasksByPlan tbp);

    SELECT *
    FROM #TasksByPlan tbp
    ORDER BY
       tbp.TaskName
    ,  tbp.TemplateName
    ,  tbp.PlanName;

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • And another with the same technique:
    CREATE TABLE #Template (
        TaskName VARCHAR(20),
        TemplateName VARCHAR(20)
    );
    INSERT INTO #Template (TaskName, TemplateName)
    SELECT 'Task1', 'Template 1' UNION ALL
    SELECT 'Task2', 'Template 1' UNION ALL
    SELECT 'Task3', 'Template 1' UNION ALL
    SELECT 'Task4', 'Template 1'

    SELECT *
    FROM #Template;

    CREATE TABLE #TasksByPlan (
        TaskName VARCHAR(20),
        TemplateName VARCHAR(20),
        PlanName VARCHAR(20)
    );
    INSERT INTO #TasksByPlan (TaskName, TemplateName, PlanName)
    SELECT 'Task1', 'Template 1', 'Plan1' UNION ALL
    SELECT 'Task2', 'Template 1', 'Plan1' UNION ALL
    SELECT 'Task3', 'Template 1', 'Plan1' UNION ALL
    SELECT 'Task1', 'Template 1', 'Plan2' UNION ALL
    SELECT 'Task2', 'Template 1', 'Plan2' UNION ALL
    SELECT 'Task3', 'Template 1', 'Plan2' UNION ALL
    SELECT 'Task4', 'Template 1', 'Plan2' UNION ALL
    SELECT 'Task1', 'Template 1', 'Plan3' UNION ALL
    SELECT 'Task2', 'Template 1', 'Plan3';

    SELECT TBP.TemplateName, TBP.PlanName, TBP.TaskName
    FROM #TasksByPlan AS TBP
    ORDER BY TBP.TemplateName, TBP.PlanName, TBP.TaskName;

    WITH TasksByPlan AS (

        SELECT DISTINCT TBP.TemplateName, TBP.PlanName
        FROM #TasksByPlan AS TBP
    ),
        TaskTemplate AS (

            SELECT DISTINCT T.TemplateName, T.TaskName
            FROM #Template AS T
    )
    INSERT INTO #TasksByPlan (TaskName, TemplateName, PlanName)
    SELECT TT.TaskName, TT.TemplateName, TBP.PlanName
    FROM TaskTemplate AS TT
        INNER JOIN TasksByPlan AS TBP
            ON TT.TemplateName = TBP.TemplateName
            AND TBP.PlanName + TT.TaskName NOT IN (
                SELECT TBP2.PlanName + TBP2.TaskName
                FROM #TasksByPlan AS TBP2
                WHERE TBP2.TemplateName = TBP.TemplateName
                );

    SELECT TBP.TemplateName, TBP.PlanName, TBP.TaskName
    FROM #TasksByPlan AS TBP
    ORDER BY TBP.TemplateName, TBP.PlanName, TBP.TaskName;

    DROP TABLE #TasksByPlan;
    DROP TABLE #Template;

    Steve (aka sgmunson) 🙂 🙂 🙂
    Rent Servers for Income (picks and shovels strategy)

  • Thanks All. It works perfectly .

Viewing 4 posts - 1 through 3 (of 3 total)

You must be logged in to reply to this topic. Login to reply