灵活使用Oracle 触发器类型实现更高效的数据库管理(oracle触发器类型)
在数据库管理中,有时我们需要业务逻辑触发器(trigger)来促使一组语句按照指定时间和指定条件执行,一般来说,Oracle 触发器类型比较多,一般可以分为表级别触发器和库级别触发器,而且有创建、修改、删除等操作。
首先,我们可以用下面的 SQL 语句来创建表级别触发器:
Create Trigger 触发器名称
before insert on 表名 For Each Row
begin 执行的动作;
end;
比如,我们可以在用户插入数据之前要求用户输入两个参数,分别是 SMS 号码和密码。如下:
Create Trigger Before_Insert
before insert on Users For Each Row
Begin checkinputsmsandpwd(:old.username,:old.id);
End;
其次,我们还可以创建库级别触发器用来在库操作发生时执行某些指定操作,常见的操作有日志记录等,库级别触发器也可以用来实现数据库安全。例如,下面的 SQL 语句可以创建一个用来记录数据库访问日志的库级别触发器:
Create or Replace Trigger Log_Table
After Logon Begin
Insert Into Log_Tables(username, logintime) Values(User, sysdate); End;
再比如,我们可以用触发器实现读写分离,比如创建一个实现读写分离功能的表级别触发器:
Create Trigger 分离触发器
after Insert or Update on 表名 Begin
if (Implementing_Read_Write_Split) then Select Database into 链接Database;
if (Database=