如何用FGA得到绑定变量的值

文章介绍了在9i和10g中获取SQL绑定变量值的方法。9i中有sql_trace、10046、FGA三种方式;10g除这三种外,还可使用V$SQL_BIND_CAPTURE(需设置参数,默认保存15分钟前的值)和审计。重点介绍了通过FGA获取绑定变量值的方式。

在9i中,要得到SQL绑定变量的值,主要有以下几种方式:

1、sql_trace
2、10046
3、FGA

如果是10g,除了上面的三种方法外还可以使用:
4、V$SQL_BIND_CAPTURE(需要设置数据库参数,默认情况下保存的是15分钟前的绑定变量值)
5、审计

这篇文章主要介绍如何通过FGA的方式来得到绑定变量的值。


9i中,FGA默认是收集SQL和绑定变量的信息的。

SQL> CREATE TABLE T3(C1 INT,C2 INT);

Table created

SQL> begin
2 dbms_fga.add_policy (
3 object_schema => 'SUK',
4 object_name => 'T3',
5 policy_name => 'T3_SEL',
6 audit_column => 'C1'
7 );
8 end;
9 /

PL/SQL procedure successfully completed

SQL> VAR A NUMBER
SQL> EXEC :A:=1

PL/SQL procedure successfully completed
A
---------
1

SQL> SELECT * FROM T3 WHERE C1=:A;

C1 C2
--------------------------------------- ---------------------------------------
A
---------
1

SQL> SELECT SESSION_ID,SQL_TEXT,SQL_BIND FROM DBA_FGA_AUDIT_TRAIL;

SESSION_ID SQL_TEXT SQL_BIND
---------- -------------------------------------------------------------------------------- --------------------------------------------------------------------------------
538 SELECT * FROM T3 WHERE C1=:A #1(1):1

从SQL_BIND中,我们可以看到绑定变量的值。如果同一个SQL中有绑定变量,则会在SQL_BIND中一一列出来,并用空格隔开。


如果是10G,我们在添加策略的时候需要指定audit_trail参数:
audit_trail => DBMS_FGA.DB + DBMS_FGA.EXTENDED
其中DBMS_FGA.DB表示把审计记录放在表中,DBMS_FGA.EXTENDED表示审计记录保留SQL语句及绑定变量的值。
如:
SQL> begin
2 dbms_fga.add_policy (
3 object_schema => 'SUK',
4 object_name => 'T3',
5 policy_name => 'T3_SEL',
6 audit_column => 'C1',
7 statement_types => 'SELECT',
8 audit_trail => DBMS_FGA.DB + DBMS_FGA.EXTENDED
9 );
10 end;
11 /

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/231499/viewspace-63813/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/231499/viewspace-63813/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值