优化 n^2 循环内的合并查询

Optimize Merge query inside n^2 loop

我有一个合并查询,需要为请求 ArrayList 中的每个 day 和 sessionType 组合执行一次。我正在使用 nativeQuery 来执行它。

MERGE INTO TABLE_A A
    USING 
    (
    SELECT
    :description AS DESCRIPTION,
    :sessionType AS SESSION_TYPE,
    :day AS DAY,
    :flag1 AS FLAG1,
    :flag2 AS FLAG2,
    FROM DUAL) AS SOURCE
    ON (SOURCE.DESCRIPTION=
        A.DESCRIPTION AND SOURCE.DAY=
        A.DAY
        )
    WHEN MATCHED THEN
        UPDATE SET 
        FLAG1=SOURCE.FLAG1,
        FLAG2=SOURCE.FLAG2  
    WHEN NOT MATCHED THEN
        INSERT (
        DESCRIPTION,
        SESSION_TYPE,
        DAY,
        FLAG1,
        FLAG2
        )
        VALUES (
        SOURCE.DESCRIPTION,
        SOURCE.SESSION_TYPE,
        SOURCE.DAY,
        SOURCE.FLAG1,
        SOURCE.FLAG2    
        );

有没有办法明示源数据(两个 ArrayList,一个有日期范围而不是一天,另一个有所有会话类型),这样我就可以只执行一次合并?有人告诉我这可以使用 WITH 来实现,但我不知道该怎么做。

如有任何帮助,我们将不胜感激。

  1. 你可以使用executeBatch:在这种情况下,oracle会自动在输入数组上执行你的sql语句

  2. 您可以像这样绑定一个集合并在 table() 中使用它:

MERGE INTO TABLE_A A
    USING 
    (
    SELECT *
    FROM table(:bind_collection)
    ) AS SOURCE
    ON (SOURCE.DESCRIPTION=
        A.DESCRIPTION AND SOURCE.DAY=
        A.DAY
        )
    WHEN MATCHED THEN
        UPDATE SET 
        FLAG1=SOURCE.FLAG1,
        FLAG2=SOURCE.FLAG2  
    WHEN NOT MATCHED THEN
    ...