如何用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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20200326]繫結變數抓取與NULL值.txt變數Null
- [20191213]共享池繫結變數的值在哪裡.txt變數
- [20191216]共享池繫結變數的值在哪裡2.txt變數
- [20211227]抽取跟蹤檔案中的繫結變數值.txt變數
- 在繫結變數下使用outline變數
- MySQL高階特性——繫結變數MySql變數
- [20180930]in list與繫結變數.txt變數
- [20180912]PLSLQ與繫結變數.txt變數
- Vue select 繫結動態變數Vue變數
- [20180930]in list與繫結變數個數.txt變數
- [20210120]in list與繫結變數個數.txt變數
- 【ORACLE】Oracle繫結變數知識梳理Oracle變數
- 繫結變數窺視測試案例變數
- [20221103]繫結變數的分配長度11.txt變數
- [20221030]繫結變數的分配長度10.txt變數
- 如何在對in操作使用變數繫結(轉)變數
- [20220414]toad與繫結變數peek.txt變數
- input,select, v-model 繫結的值為數字型別型別
- cursor_sharing=force強制繫結變數不會把變數值預設當成varchar2型別的理解變數型別
- C++變數總結束 | 輸出各種變數的值C++變數
- ES6:變數的結構賦值變數賦值
- V$sql查詢未使用繫結變數的語句SQL變數
- [20231210]執行計劃與繫結變數.txt變數
- [20190506]檢視巢狀與繫結變數.txt巢狀變數
- Oracle中如何查詢未使用繫結變數的SQL語句?Oracle變數SQL
- Oracle資料傾斜導致的問題-無繫結變數Oracle變數
- Oracle資料傾斜導致的問題-有繫結變數Oracle變數
- 越來越發現自己不懂的還是不少--繫結變數變數
- 透過v$sql_bind_capture 檢視繫結變數。SQLAPT變數
- vue中select繫結多個值Vue
- Drupal 如何得到欄位的值?
- 【CURSOR】Oracle繫結變數、執行計劃對遊標的影響Oracle變數
- [20210112]完善查詢繫結變數指令碼bind_cap.txt變數指令碼
- 不用第三個變數,交換變數的值變數
- 如何列印數值變數變數
- 變數的解構賦值變數賦值
- FGA審計及audit_trail引數AI
- MySQL中變數的定義和變數的賦值使用MySql變數賦值