sql 查询中的 ORA-00913
ORA-00913 in sql query
我正在使用 Oracle SQL 并且正在尝试 运行 以下查询:
INSERT
INTO data_mapp_info
(
data_mapp_info_id,
data_mapp_camp_id,
data_mapp_info,
data_mapp_info_regs,
dt_first,
dt_ult_modf,
user_ult_modf
)
VALUES
(
(SELECT MAX(data_mapp_info_id)+1 AS data_mapp_info_id
FROM MAPP.DATA_MAPP_INFO
)
,
77,
'Value 1',
(SELECT MAX(data_mapp_info_regs),
CASE data_mapp_info_regs
WHEN NULL
THEN 1
ELSE MAX(data_mapp_info_regs)+1
END
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77
),
sysdate,
sysdate,
'user.name'
) ;
对于 data_mapp_info_regs 的值我试图设置为 1 如果它是 NULL 如果设置的索引 data_mapp_camp_id 已经存在,则获取前一个最大值加一。但我收到错误 ORA-00913:“值太多”。
如何修复此查询?
这部分查询是 returning 两个值,您只能 return 一个值,因为它对应于您要插入的 table 中的单个列:
(SELECT MAX(data_mapp_info_regs),
CASE data_mapp_info_regs
WHEN NULL
THEN 1
ELSE MAX(data_mapp_info_regs)+1
END
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77
),
在我看来,第二个子查询应该修改为:
INSERT INTO data_mapp_info (data_mapp_info_id,
data_mapp_camp_id,
data_mapp_info,
data_mapp_info_regs,
dt_first,
dt_ult_modf,
user_ult_modf)
VALUES (
(SELECT MAX (data_mapp_info_id) + 1 AS data_mapp_info_id
FROM MAPP.DATA_MAPP_INFO),
77,
'Value 1',
-- This subquery should be modified
(SELECT NVL (MAX (data_mapp_info_regs), 0) + 1
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77),
--
SYSDATE,
SYSDATE,
'user.name');
我正在使用 Oracle SQL 并且正在尝试 运行 以下查询:
INSERT
INTO data_mapp_info
(
data_mapp_info_id,
data_mapp_camp_id,
data_mapp_info,
data_mapp_info_regs,
dt_first,
dt_ult_modf,
user_ult_modf
)
VALUES
(
(SELECT MAX(data_mapp_info_id)+1 AS data_mapp_info_id
FROM MAPP.DATA_MAPP_INFO
)
,
77,
'Value 1',
(SELECT MAX(data_mapp_info_regs),
CASE data_mapp_info_regs
WHEN NULL
THEN 1
ELSE MAX(data_mapp_info_regs)+1
END
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77
),
sysdate,
sysdate,
'user.name'
) ;
对于 data_mapp_info_regs 的值我试图设置为 1 如果它是 NULL 如果设置的索引 data_mapp_camp_id 已经存在,则获取前一个最大值加一。但我收到错误 ORA-00913:“值太多”。
如何修复此查询?
这部分查询是 returning 两个值,您只能 return 一个值,因为它对应于您要插入的 table 中的单个列:
(SELECT MAX(data_mapp_info_regs),
CASE data_mapp_info_regs
WHEN NULL
THEN 1
ELSE MAX(data_mapp_info_regs)+1
END
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77
),
在我看来,第二个子查询应该修改为:
INSERT INTO data_mapp_info (data_mapp_info_id,
data_mapp_camp_id,
data_mapp_info,
data_mapp_info_regs,
dt_first,
dt_ult_modf,
user_ult_modf)
VALUES (
(SELECT MAX (data_mapp_info_id) + 1 AS data_mapp_info_id
FROM MAPP.DATA_MAPP_INFO),
77,
'Value 1',
-- This subquery should be modified
(SELECT NVL (MAX (data_mapp_info_regs), 0) + 1
FROM MAPP_SOA.DATA_MAPP_info
WHERE data_mapp_camp_id = 77),
--
SYSDATE,
SYSDATE,
'user.name');