0

我与高中生(ID、姓名、年级)和喜欢(ID1、ID2)有两个关系

我想制作一个插入触发器,将记录插入到 likes 关系中。

当我在 Highschooler 关系中插入一个新的高中生时,我希望我的插入触发器将记录插入到喜欢中,并且基本上新的高中生喜欢同一年级的每个人。

我想要的是下面的东西:

create trigger R1
after insert on Highschooler
for each row
when (Old.grade = New.grade)
begin
    insert into Likes values(New.ID, Old.ID));   
end;

但是,对于插入触发器,旧引用无效!那么如何引用旧属性呢?

@Bill Gregg:感谢您的提示和解释。这就是你的建议吗?

create trigger R1
after insert on Highschooler
for each row
begin
    insert into Likes values(hs.ID, old.ID));
    select(hs.ID, old.ID from Highschooler hs, Highschooler old
    where hs.grade = old.grade and hs.ID <> old.ID
end;

我在我的 DBMS 上运行它并且它没有执行。我怀疑在插入后使用 select 语句存在一些问题。

4

1 回答 1

1

插入触发器上没有“旧”之类的东西,因为旧行不存在。您只是插入一个新行。

我想你想要的是

for each row

insert into Likes (FirstID,SecondID)
select hs.id, new.id
from HighShooler hs
where hs.grade = new.grade
and hs.id != new.id
于 2013-09-19T13:39:08.837 回答