Я хотел бы обновить таблицу с помощью слияния, и мой источник таблицы будет использовать перекрестное соединение - PullRequest
0 голосов
/ 21 июня 2019

У меня есть Table1:

IdT1 : 11, 12, 13

IdT1Group : 30,30,30

Table2:

IdT2 : 1, 2, 3, 4

IdT1 : 11, 11, 12, 12

Detail : A, B, A, B

И пользовательский тип таблицы @ T2:

IdT2 : 1, 2, 3

IdT1 : 11,11,11

Detail: A,B,C

Я хочу обновитьTable2 будет:

IdT2 : 1,2,5, 3,4,6, 7,8,9

IdT1 : 11,11,11, 12,12,12, 13,13,13

Detail : A,B,C, A,B,C, A,B,C

Итак, я использовал Merge в StoredProcedure:

;WITH Table2
    AS (SELECT Table2.* FROM Table2 INNER JOIN Table1 ON Table2.IdT1 = Table1.IdT1 AND IdT1Group = 30)
    MERGE INTO Table2 AS tblTarget
    USING (SELECT @T2.*, T1Item.IdT1 AS T1Id FROM @T2 CROSS JOIN Table1 where IdT1Group = 30)
            AS tblSource
        ON tblTarget.IdT1 = tblSource.T1Id And tblTarget.IdT2 = tblSource.IdT2

WHEN MATCHED THEN
    UPDATE 
    SET Detail = tblSource.Detail
WHEN NOT MATCHED BY SOURCE THEN
    DELETE
WHEN NOT MATCHED BY TARGET THEN            
    INSERT (IdItem, IdT2, Detail)
    VALUES (tblSource.IdT1,
            tblSource.IdT2, tblSource.Detail);

Но после того, как я попробовал свой код, мой table2 стал:

IdT2 : 1,2,5, 6,7,8, 9,10,11

IdT1 : 11,11,11, 12,12,12, 13,13,13

Detail: A,B,C, A,B,C, A,B,C

Это то, что должно быть:

IdT2 : 1,2,5, 3,4,6, 7,8,9

IdT1 : 11,11,11, 12,12,12, 13,13,13

Detail : A,B,C, A,B,C, A,B,C

1 Ответ

0 голосов
/ 21 июня 2019

Я думаю, что вывод должен выглядеть следующим образом, потому что одно из значений будет удалено.далее, я думаю, у вас есть столбец идентификатора или инкрементное значение в таблице 2 для IdT2.при удалении элемента увеличенное значение не будет вычтено.

output

        IdT2        IdT1        Detail
        ----------- ----------- -------
        1           11          A
        2           11          B
        5           11          C
        3           12          C
        6           12          A
        7           12          B
        8           13          A
        9           13          B
        10          13          C

SQL-оператор (ПРИМЕЧАНИЕ: вместо этого созданы # таблицы вместо физических таблиц)

    create table #Table1
    (
    IdT1    int , IdT1Group int
    )

    insert into #Table1
    select 11 IdT1,30  IdT1Group union all
    select 12 IdT1,30  IdT1Group union all
    select 13 IdT1,30  IdT1Group

    create table #Table2
    (
    IdT2 int identity(1,1),   IdT1     int , Detail varchar(100)
    )

    insert into #Table2
    SELECT   11 IdT1 ,'A' Detail union all
    SELECT   11 ,'B'      union all
    SELECT   12 ,'A'      union all
    SELECT   12 ,'B'

    declare @T2  table  
    (
    IdT2 int ,   IdT1     int , Detail varchar(100)
    )

    insert into @T2
    SELECT 1 IdT2 ,  11 IdT1 ,'A' Detail union all
    SELECT 2 ,  11 ,'B' union all
    SELECT 3 ,  12 ,'C'

    MERGE INTO #Table2 AS tblTarget
    USING (SELECT T2.*, T1Item.IdT1 AS T1Id FROM @T2 T2 CROSS JOIN #Table1 T1Item where IdT1Group = 30)
            AS tblSource
        ON  tblTarget.IdT1 = tblSource.T1Id   And tblTarget.IdT2 = tblSource.IdT2--tblTarget.IdT1 = tblSource.T1Id And tblTarget.IdT2 = tblSource.IdT2 

    WHEN MATCHED THEN
        UPDATE 
        SET Detail = tblSource.Detail
    WHEN NOT MATCHED BY SOURCE THEN
        DELETE
    WHEN NOT MATCHED BY TARGET THEN            
        INSERT (IdT1,  Detail)
        VALUES (tblSource.T1Id,
                 tblSource.Detail);

    select * from #Table2
    order by 2,1

    drop table #Table1
    drop table #Table2
...