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记录?

解决方案 »

  1.   

    你是使用sysman用户创建的这个触发器吧,因为SCOTT肯定不具备创建数据库事件触发器的权限。
    所以自然就2条记录了。
      

  2.   

    不是啊,我用system给scott赋预权限之后,用scott创建的
      

  3.   

    对于BEFORE LOGOFF的具体解释:
    Causes the database to fire the trigger whenever a client application logs off the database.注意:这时是Client Application,不是针对某个用户,所以即使Scott用户没有退出,也会在seesion_info中增加记录,因为有application。