关于系统事件触发器的小问题,给大分
时间:2011-12-08
来源:互联网
CREATE TABLE session_info (
username VARCHAR2(30),
logontime DATE,
session_id VARCHAR2(30),
ip_addr VARCHAR2(30),
hostname VARCHAR2(30),
auth_type VARCHAR2(30)
)
/
CREATE OR REPLACE TRIGGER trg_session_info
BEFORE LOGOFF
ON DATABASE
DECLARE
session_id VARCHAR2(30);
ip_addr VARCHAR2(30);
hostname VARCHAR2(30);
auth_type VARCHAR2(30);
logontime date;
BEGIN
SELECT sys_context ('USERENV', 'SESSIONID') -- 会话编号
INTO session_id FROM dual;
-- 用户登录的客户端IP地址
SELECT sys_context ('USERENV', 'IP_ADDRESS')
INTO ip_addr FROM dual;
-- 用户登录的客户端主机名
SELECT sys_context ('USERENV', 'HOST')
INTO hostname FROM dual;
-- 登录认证方式,数据库认证或外部认证
SELECT sys_context ('USERENV', 'AUTHENTICATION_TYPE')
INTO auth_type FROM dual;
INSERT INTO session_info
VALUES (user, sysdate, session_id,
ip_addr, hostname,auth_type);
END;
scott用户执行disconn命令后,会插入两条记录,一个是用户sysman, sessionid =0, 另一个才是scott,sessionid是正常的
求问为什么会有sysman记录?
username VARCHAR2(30),
logontime DATE,
session_id VARCHAR2(30),
ip_addr VARCHAR2(30),
hostname VARCHAR2(30),
auth_type VARCHAR2(30)
)
/
CREATE OR REPLACE TRIGGER trg_session_info
BEFORE LOGOFF
ON DATABASE
DECLARE
session_id VARCHAR2(30);
ip_addr VARCHAR2(30);
hostname VARCHAR2(30);
auth_type VARCHAR2(30);
logontime date;
BEGIN
SELECT sys_context ('USERENV', 'SESSIONID') -- 会话编号
INTO session_id FROM dual;
-- 用户登录的客户端IP地址
SELECT sys_context ('USERENV', 'IP_ADDRESS')
INTO ip_addr FROM dual;
-- 用户登录的客户端主机名
SELECT sys_context ('USERENV', 'HOST')
INTO hostname FROM dual;
-- 登录认证方式,数据库认证或外部认证
SELECT sys_context ('USERENV', 'AUTHENTICATION_TYPE')
INTO auth_type FROM dual;
INSERT INTO session_info
VALUES (user, sysdate, session_id,
ip_addr, hostname,auth_type);
END;
scott用户执行disconn命令后,会插入两条记录,一个是用户sysman, sessionid =0, 另一个才是scott,sessionid是正常的
求问为什么会有sysman记录?
作者: honkerhero 发布时间: 2011-12-08
你是使用sysman用户创建的这个触发器吧,因为SCOTT肯定不具备创建数据库事件触发器的权限。
所以自然就2条记录了。
所以自然就2条记录了。
作者: LuiseRADL 发布时间: 2011-12-08
不是啊,我用system给scott赋预权限之后,用scott创建的
作者: honkerhero 发布时间: 2011-12-08
我的测试结果:

作者: LuiseRADL 发布时间: 2011-12-08
对于BEFORE LOGOFF的具体解释:
Causes the database to fire the trigger whenever a client application logs off the database.
注意:这时是Client Application,不是针对某个用户,所以即使Scott用户没有退出,也会在seesion_info中增加记录,因为有application。
Causes the database to fire the trigger whenever a client application logs off the database.
注意:这时是Client Application,不是针对某个用户,所以即使Scott用户没有退出,也会在seesion_info中增加记录,因为有application。
作者: LuiseRADL 发布时间: 2011-12-08
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28