1.sysdba/sysoper 权限用户验证日志;
2.非sysdba/sysoper 权限用户验证日志;
3.关于sqlcode;

1.sysdba/sysoper 权限用户验证日志:
在数据库设置了参数 audit_sys_operations=true 的情况下,系统会根据 audit_trail 参数的设置记录 sysdba/sysoper 权限用户日志到 audit_file_dest
参数设置的目录下,记录日志的内容包括(数据库启动操作、登录验证信息、DML操作),其它非 sysdba/sysoper 权限的用户信息会被记录到AUD$表中;
audit_trail 可以设置为:DB、DB,EXTENDED、OS、XML,当audit_trail=xml 时产生的日志数量多慎用;

 SYS@sydb>show parameter audit

 NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
audit_file_dest string /u01/app/admin/sydb/adump
audit_sys_operations boolean TRUE
audit_syslog_level string
audit_trail string DB [sywu@wusuyuan ~]$ cd /u01/app/admin/sydb/adump
[sywu@wusuyuan adump]$ rm *
[sywu@wusuyuan adump]$ sqlplus / as sysdba
SYS@sydb>show parameter audit 查看跟踪文件:
[sywu@wusuyuan adump]$ ls
sydb_ora_26587_1.aud
[sywu@wusuyuan adump]$ cat sydb_ora_26587_1.aud
Thu May 29 12:48:05 2014 +08:00
LENGTH : ''
ACTION :[] 'CONNECT' --执行操作,相关操作参照 audit_actions 表
DATABASE USER:[] '/'
PRIVILEGE :[] 'SYSDBA'
CLIENT USER:[] 'sywu'
CLIENT TERMINAL:[] 'pts/0'
STATUS:[] '' --状态,登录成功为:'0',失败为:'1017',值是数据库返回的sqlcode,
DBID:[] '' Thu May 29 12:48:05 2014 +08:00
LENGTH : ''
ACTION :[] 'BEGIN DBMS_OUTPUT.ENABLE(NULL); END;'
DATABASE USER:[] '/'
PRIVILEGE :[] 'SYSDBA'
CLIENT USER:[] 'sywu'
CLIENT TERMINAL:[] 'pts/0'
STATUS:[] ''
DBID:[] '' Thu May 29 12:48:23 2014 +08:00
LENGTH : '' --show parameter audit 语句产生的后台查询
ACTION :[] 'SELECT NAME NAME_COL_PLUS_SHOW_PARAM,DECODE(TYPE,1,'boolean',2,'string',3,'integer',4,'file',5,'number', 6,'big integer', 'unknown') TYPE,DISPLAY_VALUE VALUE_COL_PLUS_SHOW_PARAM FROM V$PARAMETER WHERE UPPER(NAME) LIKE UPPER(:NMBIND_SHOW_OBJ) ORDER BY NAME_COL_PLUS_SHOW_PARAM,ROWNUM'
DATABASE USER:[] '/'
PRIVILEGE :[] 'SYSDBA'
CLIENT USER:[] 'sywu'
CLIENT TERMINAL:[] 'pts/0'
STATUS:[] ''
DBID:[] ''

如果数据库启动为只读模式,则audit_trail 值默认为:OS;

 AUDIT_TRAIL initialization parameter is changed to OS, as DB,EXTENDED is NOT compatible for database opened with read-only access

2.非sysdba/sysoper 权限用户验证日志:
非sysdba/sysoper 权限用户验证日志会被记录在AUD$系统表上,aud$记录用户验证userId,userhost,action#,comment$text,process#,dbid..,当用户断开连接时
记录用户断开时间(LOGOFF$TIME);

 SYS@sydb> select sessionid,userhost,userid,to_char(TIMESTAMP#,'YYYY-MM-DD HH24:mi:ss')TIMESTAMP,action#,process#,LOGOFF$TIME,RETURNCODE
2 from aud$ where userid=upper('SYWU'); SESSIONID USERHOST USERID TIMESTAMP ACTION# PROCESS# LOGOFF$TIME RETURNCODE
---------- --------------- ------------- ------------------- ---------- ---------------- ------------------- ----------
########## wusuyuan SYWU 101 25404 2014-06-04 12:40:24 0
########## wusuyuan SYWU 100 25411 0
########## wusuyuan SYWU 101 25411 2014-06-04 12:41:18 0
########## wusuyuan SYWU 100 25413 0
########## wusuyuan SYWU 101 25413 2014-06-04 12:46:51 0
########## wusuyuan SYWU 100 25444 0
########## wusuyuan SYWU 101 25444 2014-06-04 12:50:36 0

sys.AUD$ 表所有者是SYS用户,占用SYSTEM表空间,长时间使用会存储很多信息,可以在sysdba权限用户下(截取、删除)数据:

 SYS@sydb>truncate table aud$;

也可以将表存储到其它表空间下:

 SYS@sydb>alter table aud$ move tablespace tbs02;

3.关于sqlcode:
在执行任何sql 时,后台都会返回sqlcode值,执行正确默认返回'0',如果发生错误或异常是返回错误值,类似我们看到的 ORA-00001 错误;

  OPS$LANSTON@sydb>declare
2 v_date date;
3 begin
4 select sysdate into v_date from dual;
5 dbms_output.put_line('this is v_date value:'||v_date);
6 dbms_output.put_line('this is database return sqlcode:'||sqlcode);
7 end;
8 /
this is v_date value:2014-06-04 21:12:51
this is database return sqlcode:0 PL/SQL procedure successfully completed.

当执行出错时:

 OPS$LANSTON@sydb>   declare
2 v_date date;
3 begin
4 execute immediate 'select tcol from dual' into v_date;
5
6 exception when others then
7 dbms_output.put_line('this is database return sqlcode:'||sqlcode);
8 dbms_output.put_line('this is database return error message:'||sqlerrm);
9 end;
10 /
this is database return sqlcode:-904
this is database return error message:ORA-00904: "TCOL": invalid identifier PL/SQL procedure successfully completed.

在PL/SQL体内执行DML操作时,建议使用 execute immediate 执行,这样容易捕获错误,并且可以在异常体对异常处理;如上例子如果不使用execute immediate 执行,数据库
在第一时间就抛出错误并终止程序运行;

Oracle 用户验证日志的更多相关文章

  1. Oracle用户,权限,角色以及登录管理 scoot 授权

    Oracle用户,权限,角色以及登录管理 1. sys和system用户的区别 system用户只能用normal身份登陆em.除非你对它授予了sysdba的系统权限或者syspoer系统权限. sy ...

  2. Oracle用户、角色、权限

    一.Oracle权限 系统权限:系统规定用户使用数据库的权限.(系统权限是对用户而言) 对象权限:某种权限用户对其它用户的表或视图的存取权限.(是针对表或视图而言的) 1.Oracle系统权限 ​ o ...

  3. Oracle补全日志(Supplemental logging)

    Oracle补全日志(Supplemental logging)特性因其作用的不同可分为以下几种:最小(Minimal),支持所有字段(all),支持主键(primary key),支持唯一键(uni ...

  4. Oracle用户被锁原因及办法

    Oracle用户被锁原因及办法   在登陆时被告知test用户被锁 1.用dba角色的用户登陆,进行解锁,先设置具体时间格式,以便查看具体时间 SQL> alter session set nl ...

  5. 归档—监控ORACLE数据库告警日志

    ORACLE的告警日志里面包含许多有用的信息,尤其是一些ORACLE的ORA错误信息,所以有必要及时归档.监控数据库告警日志的ORA错误,及时提醒数据库管理员DBA处理这些错误信息,那么我们首先来看看 ...

  6. 使用JDBC实现Oracle用户认证

    两天时间写的小品,以前的J2EE环境基本使用框架.现在使用JDBC配合Oracle存储过程模拟了一下用户注册和用户认证. 一.添加必须的jar包 需要JDBC连接Oracle的包和shiro-core ...

  7. Linux Oracle删除归档日志

    今天遇到Oracle报这样的错:ORA-00257 查看了下,原来是Oracle的归档日志满了,解决方案两个 一:增加归档日志大小 二:删除无用的归档日志(我们选择这个方案) 什么也不说了Linux下 ...

  8. 【密码】Oracle用户密码系列

    [密码]Oracle用户密码系列 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识, ...

  9. Oracle—用户管理的完全恢复(四)

    在用户管理的备份(三)中,最后打开数据库时,用了alter database open resetlogs;的命令,这里为什么用resetlogs命令? 一.resetlogs的作用 1.将当前的日志 ...

随机推荐

  1. java代码=====实现修改while()

    总结: package com.mmm; public class cse { public static void main(String[] args) { // int count=0;你妹,我 ...

  2. Java 方法签名

    方法签名格式: 方法名   参数列表 例如: public class A{ protected int method (int a, int b) { return 0; } } class B e ...

  3. sersync之不洗澡

    inotiry图片参考 sersync图片参考 inotify文字教程 该软件对系统有要求,内核2.6以上,并且有如下目录,后面会讲解三个文件用途 [root@jokerpro ~]# uname - ...

  4. 多个else if语句

    public class demo { public static void main(String[] args) { boolean examIsDone = true; int score = ...

  5. GIL线程与进程选择

    #!/usr/bin/env python # encoding: utf-8  # Date: 2018/6/18 # 计算密集型.应该启动多进程# from multiprocessing imp ...

  6. BFC以及margin的深入探究

    BFC(Block Formatting Context) 块级格式化上下文,它是指一个独立的块级渲染区域,只有block-level Box参与,该区域拥有一套渲染规则来约束块级盒子的布局,且与区域 ...

  7. OD 界面简介

    1 为汇编代码对应的地址窗口 2 为汇编代码对应的十六进制机器码窗口 3 为反汇编窗口 4 为反汇编代码对应的注释信息窗口 5 为寄存器信息窗口 6 为当前执行到的反汇编代码的信息窗口 7~9 为数据 ...

  8. pycharm多行代码同时注释、去除注释

    pycharm中同时注释多行代码快捷键: 代码选中的条件下,同时按住 Ctrl+/,被选中行被注释,再次按下Ctrl+/,注释被取消

  9. sql server 2008 链接到数据库引擎

  10. MySQL多项模糊查询

    最近有个需求,就是要根据搜索框里面的关键字,找到符合条件的数据. 如果是单个条件的话,其实就是一个普通的select语句. 但是需求是这个关键字,要在id,desc,step等多个字段模糊查找. 然后 ...