logon on database记录登入信息的trigger

今天想起写一个登陆数据库的数据库级别的trigger,记录每次登陆的时间和人员名称,以下是具体的构建思路。

SQL> create table loggon01(id number,name varchar2(80),logon_date date);

Sql> create public synonym loggon for loggon01;

Sql> grant all on logon to public;

创建测试表loggon01及其public synonym授权与public

Sql> create sequence sequence01

Start with 1

Increment by 1

Maxvalue 99999

Nocycle

Sql> create public synonym sequence for sequence01;

Sql> grant select any sequence to public;

创建序列及其public synonym并授权与public

Sql> create or replace trigger trigger01

After logon on database /*如果用schema替换databasetrigger只会记录本用户的记录信息。*/

Begin

Insert into logon values(sequence.nextval,user,sysdate);

End;

创建logon on database触发器,记录每次登陆人员信息。

SQL> delete from loggon;

28 rows deleted

SQL> disconnect;

Not logged on

清空数据,并logoff database

SQL> conn xiaoyu/xiaoyu;

Connected to Oracle Database 10gEnterprise Edition Release 10.2.0.1.0

Connected as xiaoyu

SQL> select * from loggon;

ID NAME LOGG_DATE

---------- -------------------- -----------

54 XIAOYU 2012-1-18 1

57 XIAOYU 2012-1-18 1

55 XIAOYU 2012-1-18 1

56 DBSNMP 2012-1-18 1

从上述可以得出sequence也可以授予同义词,实现某种算法应该用批量更新数据一样,分批算法从而简化思路逐步完成,应该也是所谓细化算法,逐步实现。

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/25362835/viewspace-1057165/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/25362835/viewspace-1057165/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值