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记录?
解决方案 »
- 如何解决多次查询多个表得到的结果集用游标输出
- oracle习题
- ORA-04098: trigger 'SYSTEM.POLICYPATHTABLE_TRG' is invalid and failed re-validat
- 为什么之前改了监听器配置后可以用jdbc连接数据库,现在连sql plus都等不了??
- pl/sql 连不上服务器的oracle
- 在oracle develop 2000工具form build中怎样调用windows 应用程序???
- 如何查询某段日期内某个时间段的数据?
- 请问,pl/sql中的tool => session 能保持多长时间?
- 触发器问题,送分的
- Help me!请问Oracle中哪里有PL/SQL的详细帮助,象SQL Server中的T-SQL帮助一样的东西?
- oracle 数据库无法启动
- 关于create directory的问题
所以自然就2条记录了。
Causes the database to fire the trigger whenever a client application logs off the database.注意:这时是Client Application,不是针对某个用户,所以即使Scott用户没有退出,也会在seesion_info中增加记录,因为有application。