我正在尝试将数据合并到数据库中,所以我不能没有表,并且我不想创建一个临时表只是在以后删除
MERGE INTO target_table target
USING ('0101-2019' as date, 1515 as random_data, 9595 as more_random_data) source
ON (target.date= source.date)
WHEN MATCHED THEN
UPDATE SET target.date = source.date,
target.random_data = source.random_data,
target.more_random_data = source.more_random_data
WHEN NOT MATCHED THEN
INSERT (date, random_data, more_random_data)
VALUES (source.date, source.random_data, source.more_random_data);
由于某种原因,如果我不使用Oracle SQL Developer,但无法将其转换为Oracle,我会找到一种可行的方法
MERGE target_table AS target
USING (VALUES ('0101-2019', 1515, 9595))
AS source(date, random_data, more_random_data)
ON target.date= source.date
WHEN MATCHED THEN
UPDATE SET target.date = source.date,
target.random_data = source.random_data
target.more_random_data = source.more_random_data
WHEN NOT MATCHED BY target THEN
INSERT (date, random_data, more_random_data)
VALUES (source.date, source.random_data, source.more_random_data)
WHEN NO TMATCHED BY source THEN
DELETE
不要问我这将在哪里工作,这是我从一些适合我的情况的示例中发现的,但是由于我使用Oracle的SQL Developer,因此对我不起作用。
答案 0 :(得分:1)
Oracle仍然不支持标准的VALUES行构造函数。您需要对select from dual
使用解决方法:
USING (
select '0101-2019' as date, 1515 as random_data, 9595 as more_random_data
from dual
) source