codecamp

OceanBase AUDIT

描述

该语句用于配置或删除对 SQL 语句的审计规则。

说明 
  • 配置对 SQL 语句的审计规则时,您必须拥有 ​AUDIT SYSTEM​ 系统权限,且需要登录 ORAAUDITOR 用户,密码固定为 ORAAUDITOR。
  • 配置对 SQL 语句的审计规则后,对所有会话立即生效。
  • 需要通过系统配置项 audit_trail 开启审计功能,该语句配置的审计规则才能生效。

格式

/*语句审计*/
{AUDIT | NOAUDIT} statement_operation_clause [auditing_by_user_clause] [whenever_option]

/*对象审计*/
{AUDIT | NOAUDIT} object_operation_clause auditing_on_clause [whenever_option]

statement_operation_clause:
    statement_operation_list
    | ALL
    | ALL STATEMENTS

statement_operation_list:
    statement_operation [statement_operation...]

object_operation_clause:
    object_operation_list
    | ALL

object_operation_list:
    object_operation [object_operation...]

auditing_on_clause:
    ON obj_name
    | ON DEFAULT

auditing_by_user_clause:
    BY user_name [user_name...]

whenever_option:
WHENEVER NOT SUCCESSFUL
| WHENEVER SUCCESSFUL

statement_operation:
    ALTER SYSTEM
    | CLUSTER
    | CONTEXT
    | DATABASE LINK
    | MATERIALIZED VIEW
    | NOT EXISTS
    | OUTLINE
    | PROCEDURE
    | PROFILE
    | PUBLIC DATABASE LINK
    | PUBLIC SYNONYM
    | ROLE
    | SEQUENCE
    | SESSION
    | SYNONYM
    | SYSTEM AUDIT
    | SYSTEM GRANT
    | TABLE
    | TABLESPACE
    | TRIGGER
    | TYPE
    | USER
    | VIEW
    | ALTER SEQUENCE
    | ALTER TABLE
    | COMMENT TABLE
    | DELETE TABLE
    | EXECUTE PROCEDURE
    | GRANT PROCEDURE
    | GRANT SEQUENCE
    | GRANT TABLE
    | GRANT TYPE
    | INSERT TABLE
    | SELECT SEQUENCE
    | SELECT TABLE
    | UPDATE TABLE

object_operation:
    ALTER
    | AUDIT
    | COMMENT
    | DELETE
    | EXECUTE
    | FLASHBACK
    | GRANT
    | INDEX
    | INSERT
    | RENAME
    | SELECT
    | UPDATE

参数解释

参数

描述

statement_operation

语句审计操作类型。

  • 如果指定 ALL,表示所有 审计语句说明表 1 中的操作。

  • 如果指定 ALL STATEMENTS,表示 statement_operation 中的所有操作。

object_operation

对象审计操作类型。

obj_name

被审计的对象名,支持的对象类型包括:

  • table

  • view

  • sequence

ON DEFAULT

设置默认审计规则,对后续新创建的对象生效。

user_name

指定用户名。

WHENEVER NOT SUCCESSFUL

指定只有执行失败才触发审计。

WHENEVER SUCCESSFUL

指定只有执行成功才触发审计。

可以审计的 SQL 语句类型如下表所示。

审计语句说明表 1

审计语句

说明

ALTER SYSTEM

审计 ALTER SYSTEM 语句。

CLUSTER

审计 ADD CLUSTER 和 REMOVE CLUSTER 语句。

INDEX

审计 CREATE/DROP/FLASHBACK/PURGE INDEX 语句。

NOT EXISTS

审计因对象不存在导致失败的操作。

OUTLINE

审计 CREATE/ALTER/DROP OUTLINE 语句。

PROCEDURE

审计 CREATE/DROP PROCEDURE、CREATE/DROP FUNCTION 和 CREATE/DROP PACKAGE 语句。

PROFILE

审计 CREATE/ALTER/DROP PROFILE 语句。

ROLE

审计 CREATE/ALTER/DROP/SET ROLE 语句。

SEQUENCE

审计 CREATE/DROP SEQUENCE 语句。

SESSION

审计登入登出操作。

SYNONYM

审计 CREATE/DROP SYNONYM 语句。

SYSTEM AUDIT

审计 AUDIT/NOAUDIT 语句。

SYSTEM GRANT

审计 GRANT/REVOKE 语句。

TABLE

审计 CREATE/DROP/TRUNCATE TABLE 语句。

TABLESPACE

审计 CREATE/ALTER/DROP TABLESPACE 语句。

TRIGGER

审计 CREATE/ALTER/DROP TRIGGER 语句。

TYPE

审计 CREATE/DROP TYPE 或 CREATE/DROP TYPE BODY 语句。

USER

审计 CREATE/ALTER/DROP USER 语句。

VIEW

审计 CREATE/DROP VIEW 语句。

审计语句说明表 2

审计语句

说明

ALTER SEQUENCE

审计 ALTER SEQUENCE 语句。

ALTER TABLE

审计 ALTER TABLE 语句。

COMMENT TABLE

审计 COMMENT ON TABLE/VIEW 语句。

DELETE TABLE

审计 DELETE FROM TABLE/VIEW 语句。

EXECUTE PROCEDURE

审计 CALL 语句。

GRANT PROCEDURE

审计 GRANT/REVOKE obj_privilege ON PROCEDURE/FUNCTION/PACKAGE 语句。

GRANT SEQUENCE

审计 GRANT/REVOKE obj_privilege ON SEQUENCE 语句。

GRANT TABLE

审计 GRANT/REVOKE obj_privilege ON TABLE/VIEW 语句。

GRANT TYPE

审计 GRANT/REVOKE obj_privilege ON TYPE 语句。

INSERT TABLE

审计 INSERT INTO TABLE/VIEW 语句。

SELECT SEQUENCE

审计所有包含 sequence.CURRVAL 或 sequence.NEXTVAL 的语句。

SELECT TABLE

审计 SELECT TABLE/VIEW 语句。

UPDATE TABLE

审计 UPDATE TABLE/VIEW 语句。

示例

  • 对 test 用户的 table 相关操作语句在执行成功的情况下进行审计。
//将 ORAAUDITOR 用户解锁。
obclient> alter user ORAAUDITOR account unlock;
Query OK, 0 rows affected (5.76 sec)

//登录 ORAAUDITOR 用户。
obclient> exit;
Bye
[admin@k08j13249.eu95sqa /home/admin]
$obclient -h10.10.10.10 -P2883 -uORAAUDITOR@Oracle#test -pORAAUDITOR

obclient> AUDIT TABLE BY test WHENEVER SUCCESSFUL;
Query OK, 0 rows affected (21.14 sec)
  • 对表 t1 的所有 INSERT、UPDATE 和 DELETE 操作进行审计。
obclient> AUDIT INSERT, UPDATE, DELETE on t1;
Query OK, 0 rows affected (31.62 sec)


OceanBase UPDATE
OceanBase EXPLAIN
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

OceanBase 控制台指南

OceanBase ODC 使用指南

OceanBase Web 版 ODC

OceanBase 客户端版 ODC

OceanBase Connector/J 开发者指南

OceanBase 什么是OceanBase Connector/J

OceanBase SQL 参考(MySQL 模式)

OceanBase SQL 参考(Oracle 模式)

OceanBase 基本元素

OceanBase 数据库对象

OceanBase 函数

OceanBase 单行函数

OceanBase 返回数字的字符串函数

OceanBase 通用比较函数

OceanBase 编码解码函数

OceanBase SQL 调优指南

OceanBase 相关协议

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }