June 20, 2018 at 12:33 pm
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
June 20, 2018 at 12:50 pm
Here is one wayWITH 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
June 20, 2018 at 12:57 pm
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)
June 21, 2018 at 7:44 am
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