sql触发器使用两个表数据

时间:2013-05-12 10:31:16

标签: sql oracle triggers

所以我有三张桌子。前两个有ID列和“rank”列(整数)。我将在第三个表中插入两个ID(ID1,ID2)但我需要触发器来检查它们是否在我可以插入之前是相同的等级。我无法让它发挥作用。

CREATE OR REPLACE TRIGGER TRIGGER1 
AFTER INSERT ON TABLE_C 

BEGIN
IF NOT EXISTS (
SELECT TABLE_A.id, TABLE_B.id
FROM TABLE_A JOIN TABLE_B ON TABLE_A.rank = TABLE_B.rank
WHERE TABLE_A.id = inserted.id1 AND TABLE_B.id = inserted.id2 )
THEN
PRINT 'Not the same rank'
ROLLBACK
END
END;

我正在使用Oracle db。

2 个答案:

答案 0 :(得分:1)

触发器有两种,BEFOREAFTER触发器。如果要在插入数据之前检查数据是否具有相同的排名,则应使用 BEFORE 触发器。

CREATE OR REPLACE TRIGGER TRIGGER1 
BEFORE INSERT ON TABLE_C

然后逻辑将会跟随。

更新:您可以轻松raise application error。如:

IF HasSameRank == 0 THEN
    raise_application_error(-21013, 'Not the same rank');
END IF;

答案 1 :(得分:1)

您无法在Oracle触发器中使用“回滚”或“提交” - please refer this

我认为你可以修改你的触发器 -

CREATE OR REPLACE TRIGGER Trigger1
    AFTER INSERT ON Table_c
    FOR EACH ROW
  DECLARE
    l_Count NUMBER := 0;
  BEGIN
    SELECT COUNT(*)
      INTO l_Count
      FROM Table_a
      JOIN Table_b ON Table_a.Rank = Table_b.Rank
     WHERE Table_a.Id = :NEW.Id1
       AND Table_b.Id = :NEW.Id2;
    IF l_Count = 0 THEN
      DELETE FROM Table_c
       WHERE Id1 = :NEW.Id1
         AND Id2 = :NEW.Id2;
      --PRINT 'Not the same rank'
      Dbms_Output.Put_Line('Not the same rank');
    END IF;
  END;
/