SQL 从一个 Table A 更新到 table B 基于基于点聚合的匹配 2 ID

SQL update from one Table A to table B based on match 2 ID based on aggregation of points

试图将值从table(first_stage更新为table(final),这两个table的字段名称相同但值不同,table的内容是:

(Min_Date) date, 
(Max_Date) date, 
(NoofDays) int, 
(IMSI) string, 
(Site) string, 
(Down_Link) int, 
(Up_Link) int, 
(Connection) int 

基于 IMSI 和站点,如果它存在于 table 行,则取最小日期为 Min_Date 最大日期为 Max_Date 并得到

min(Min_Date),max(Max_Date)sum(NoofDays),sum(Down_Link),sum(up_Link),sum(connection)

如果两个行 ID 都不匹配(IMSI、站点)与 table(最终),则将该行插入最终 table。我还是 sql

的新手
table first_stage:
MinDate    Max_Date  NoofDays  IMSI  Site   Down_link  Up_link  Connection
2019-03-22 2019-03-26   1       222  google    1        1         1
2019-03-26 2019-03-27   3       222  youtube   1        1         1
2019-03-02 2019-03-27   5       333  facebook  2        3         1
2019-03-02 2019-03-27   5       111  facebook  20       33        11



table final:
MinDate    Max_Date  NoofDays  IMSI  Site   Down_link  Up_link  Connection
2019-03-01 2019-03-27   1       222  google    2        2         1
2019-03-12 2019-03-25   1       222  youtube   2        2         2
2019-03-25 2019-03-27   4       333  facebook  3        6         1

必须同时匹配IMSI和Site才能进行更新声明,更新后的最终table必须如下所示:

table final:
MinDate    Max_Date  NoofDays  IMSI  Site   Down_link  Up_link  Connection
2019-03-01 2019-03-27   2       222  google    3        3         2
2019-03-12 2019-03-27   4       222  youtube   3        3         3
2019-03-02 2019-03-27   9       333  facebook  5        9         2
2019-03-02 2019-03-27   5       111  facebook  20       33        11

我从未使用过 vertica,但我认为这可能有效:

MERGE 
INTO FINAL 
USING FIRST_STAGE
ON IMSI = FIRST_STAGE.IMSI and Site = FIRST_STAGE.Site
WHEN MATCHED THEN UPDATE SET
  Min_Date = least(FIRST_STAGE.Min_Date, Min_Date),
  Max_Date = greatest(FIRST_STAGE.Max_Date, Max_Date),
  NoofDays = FIRST_STAGE.NoofDays + NoofDays,
  Down_Link = FIRST_STAGE.Down_Link + Down_Link,
  up_Link = FIRST_STAGE.up_Link + up_Link,
  connection = FIRST_STAGE.connection + connection
WHEN NOT MATCHED THEN INSERT ( Min_Date, 
  Max_Date, 
  NoofDays, 
  IMSI, 
  Site, 
  Down_Link, 
  Up_Link, 
  Connection )
VALUES ( FIRST_STAGE.Min_Date, 
  FIRST_STAGE.Max_Date, 
  FIRST_STAGE.NoofDays, 
  FIRST_STAGE.IMSI, 
  FIRST_STAGE.Site, 
  FIRST_STAGE.Down_Link, 
  FIRST_STAGE.Up_Link, 
  FIRST_STAGE.Connection )