0

我正在尝试从 select 语句中将一些数据插入到表中。我知道我可以这样做:

insert into new_logs (idLog, logEntry)
(select idLog, logEntry from old_logs)

但是,当我需要传入一个序列值时,我在尝试执行这种类型的查询时遇到了问题:

insert into new_logs (idLog, logEntry)
(select LOGSEQ.NEXTVAL, logEntry from old_logs) 

我认为问题是因为序列来自对偶表,但上面的查询暗示它来自 old_logs 表。

这个我也试过

insert into new_logs (idLog, logEntry)
select next_value for LOGSEQ, logEntry from old_logs

但我仍然无法让它工作。有人可以告诉我我想做的事情是否可行吗?我要做的就是使用选择查询 另一个模式上的序列运行插入语句。

4

2 回答 2

1

如果您在 old_logs 中有重复的 logentry 字段,您的查询插入 new_logs(idLog,logEntry)(从 old_logs 中选择 LOGSEQ.NEXTVAL,logEntry)可能会出错。

尝试这个:-

    insert into new_logs (idLog, logEntry)
select LOGSEQ.NEXTVAL, logEntry from (select distinct logEntry  from old_logs);
于 2013-10-23T11:51:52.980 回答
0

你的查询是正确的,如下图:

SQL> CREATE TABLE old_logs AS
  2     SELECT ROWNUM idLog, 'a' logEntry FROM dual CONNECT BY LEVEL <= 10;

Table created

SQL> CREATE TABLE new_logs AS
  2     SELECT * FROM old_logs WHERE 1 = 2;

Table created

SQL> CREATE SEQUENCE logseq;

Sequence created

SQL> INSERT INTO new_logs (idLog, logEntry)
  2  (SELECT LOGSEQ.NEXTVAL, logEntry FROM old_logs);

10 rows inserted

你到底得到了什么错误信息?

于 2013-10-22T16:10:04.527 回答