SQLite 触发器(Trigger)是数据库的回调函数,它会在指定的数据库事件发生时自动执行/调用。以下是关于SQLite的触发器的要点:
- SQLite的触发器可以指定在特定的数据库表发生DELETE、INSERT或UPDATE时触发,或一个或多个指定表的列发生更新时触发。
- SQLite只支持FOR EACH ROW 触发器,没有FOR EACH STATEMENT 触发器(Triger)。因此,明确指定FOR EACH ROW是可选的。
- WHEN子句和触发器动作可能访问使用表单NEW.column-name和OLD.column-name的引用插入、删除或更新的行元素,其中column-name是从与触发器关联的表的列的名称。
- 如果提供WHEN子句,则只针对WHEN子句为真的指定行执行SQL语局。如果没有提供WHEN子句,则针对所有行执行SQL语句。
- BEFORE或AFTER关键字决定何时执行触发器动作,决定是在关联行的插入、修改或删除之前或者之后执行触发器动作。
- 当触发器相关联的表删除时,自动删除触发器。
- 要修改的表必须存在于同一数据库中,作为触发器被附加的表或视图,且必须只使用tablename,而不是database.tablename。
- 一个特殊的SQL函数RAISE()可用于触发器程序内抛出异常。
语法
创建触发器的基本语法如下:
REATE TRIGGER trigger_name [BEFORE|AFTER] event_name
ON table_name
BEGIN
-- Trigger logic goes here....
END;
在这里,