在ADF中跟蹤SQL執行時間實現代碼

ADF是oracle提供的一套企業開發的解決方案,本文將實現在ADF中跟蹤SQL執行時間

ADF是oracle提供的一套企業開發的解決方案。
最近做性能測試, 需要獲取當前頁面有多少SQL 查詢,花費多少時間。首先想到的就是常用的log4jdbc 結果 ADF 不支持封裝的驅動。后嘗試在Orace DB 層面上攔截,比較復雜還要設置數據庫連接的sesson屬性,也要修改以后代碼。

ADF 的ViewObjectImp 提供復寫SQL調用的方法,但需要修改已有代碼,最后還是修改ADF源碼來達到不修改已有代碼而獲取到SQL執行時間。

先用改好的adfm.jar 覆蓋已有的, 配置虛擬機啟動參數 -DSQLTruckerToFile=D:log.txt -DenableSQLTracker=true
重啟就可以看到SQL 執行時間了

195:SELECT Geos.CREATED_BY, Geos.CREATED_TS, Geos.FAX_NUMBER, Geos.FROM_EMAIL_ADDRESS, Geos.ID, Geos.MODIFIED_BY, Geos.MODIFIED_TS, Geos.NAME, Geos.PHONE_NUMBER, Geos.REPLY_TO_EMAIL_ADDRESS, Geos.IS_DEFAULT FROM GEOS Geos ORDER BY Geos.IS_DEFAULT,Geos.NAME
195:729

? 版權聲明
THE END
喜歡就支持一下吧
點贊11 分享