优化 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 来实现,但我不知道该怎么做。
如有任何帮助,我们将不胜感激。
你可以使用executeBatch
:在这种情况下,oracle会自动在输入数组上执行你的sql语句
您可以像这样绑定一个集合并在 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
...
我有一个合并查询,需要为请求 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 来实现,但我不知道该怎么做。
如有任何帮助,我们将不胜感激。
你可以使用
executeBatch
:在这种情况下,oracle会自动在输入数组上执行你的sql语句您可以像这样绑定一个集合并在
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
...