关于系统事件触发器的小问题,给大分
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记录?
------解决方案--------------------
你是使用sysman用户创建的这个触发器吧,因为SCOTT肯定不具备创建数据库事件触发器的权限。
所以自然就2条记录了。