我想要创建一个触发器来验证出生日期,例如,它不是SYSDATE:
Employee -- STRUCTURED TYPE
{
name VARCHAR2(10)
lastname VARCHAR(10)
birthdate DATE
}
Employee_List TABLE OF Employee -- NESTED TABLE
Museum -- TABLE
{
id NUMBER
EmployeeList Employee_List
}我在用甲骨文10g。
发布于 2013-11-27 07:25:51
您不能定义像“在Museum.EmployeeList.birthdate更新之前”这样的触发器,但是您可以在博物馆更新之前编写一个普通触发器,在触发器体中可以遍历所有检查日期的员工。
试试这个:
CREATE OR REPLACE TRIGGER BUIR_Museum
BEFORE INSERT OR UPDATE ON Museum
FOR EACH ROW
BEGIN
IF :NEW.EmployeeList IS NOT NULL THEN
FOR i IN :NEW.EmployeeList.FIRST..:NEW.EmployeeList.LAST LOOP
IF :NEW.EmployeeList(i).birthdate > SYSDATE THEN
RAISE_APPLICATION_ERROR(-20029, 'Invalid birthday');
END IF;
END LOOP;
END IF;
END;https://stackoverflow.com/questions/20232794
复制相似问题