user_source檢視使用&&查詢包和過程中的特定內容
user_source檢視使用&&查詢包和過程中的特定內容
今天將以前的工作整理了一下,想要檢查一下以前開發的procedure、package(body)是否正確。
處於業務上的考慮,我要確認一下程式碼中是否有'au'這個schema名稱沒有替換的。
經過查詢,使用如下語句:
select * from user_source
where text like '%au%'
SQL> desc user_source
Name Type Nullable Default Comments
---- -------------- -------- ------- ------------------------------------------------------------------------------------------------------------------------
NAME VARCHAR2(30) Y Name of the object
TYPE VARCHAR2(12) Y Type of the object: "TYPE", "TYPE BODY", "PROCEDURE", "FUNCTION",
"PACKAGE", "PACKAGE BODY", "LIBRARY" or "JAVA SOURCE"
LINE NUMBER Y Line number of this line of source
TEXT VARCHAR2(4000) Y Source text
通過這個表方便地得到了我想要的內容,可以直接找到是哪個物件下的哪行沒有修改。
顯示的結果中包含編譯未通過的物件,而且內容是一模一樣的。
嘗試在原始碼中新增空行,再次查詢後,結果也會多一個空行。
用這種方式查詢,發現結果中含有'default'這個我不需要的內容,也過濾出來了。
這時我希望得到like '%au%' 但不是'%default%'的內容。
最先想到:
select * from user_source
where text like '%au%' and text not like '%default%' ;
然後在儲存過程中新增了三行:
--au (第一行)
--default (第二行)
--au default (第三行)
查詢結果只能得到第一行
通過dba_source可以看到所有使用者的包和儲存過程的內容,當然,不包括經過加密處理的。
select * from user_source where instr(text,'au')<>0;
Execution Plan
----------------------------------------------------------
Plan hash value: 4266197181
Statistics
----------------------------------------------------------
24091 recursive calls
0 db block gets
106929 consistent gets
303 physical reads
0 redo size
3337619 bytes sent via SQL*Net to client
4259 bytes received via SQL*Net from client
351 SQL*Net roundtrips to/from client
2 sorts (memory)
0 sorts (disk)
5238 rows processed
SQL> select * from user_source where text like '%au%' ;
5238 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 3439453968
Statistics
----------------------------------------------------------
24113 recursive calls
0 db block gets
106942 consistent gets
0 physical reads
0 redo size
3337619 bytes sent via SQL*Net to client
4259 bytes received via SQL*Net from client
351 SQL*Net roundtrips to/from client
3 sorts (memory)
0 sorts (disk)
5238 rows processed
“instr”方式進行了三百多次的物理讀操作,而“like”方式沒有。因此like方式比較好。
如果當前有如下內容:
NAME TYPE LINE TEXT
1 P_TEST PROCEDURE 4 " --au
"
2 P_TEST PROCEDURE 5 " --default
"
3 P_TEST PROCEDURE 6 " --au default
"
4 P_TEST PROCEDURE 7 " --default au
"
5 P_TEST PROCEDURE 8 " --defaull
"
想要得到:
1 P_TEST PROCEDURE 4 " --au"
3 P_TEST PROCEDURE 6 " --au default"
4 P_TEST PROCEDURE 7 " --default au"
5 P_TEST PROCEDURE 8 " --defaull"
應該如何編寫語句呢?
注意到:只要au的數量和default的數量不一樣,就是滿足條件的。
那麼怎樣得到數量呢?
從這個網址得到了啟示:http://www.itpub.net/thread-1164382-1-1.html
select length(str)-length(replace(str,'s_tr','')) from table
是從str欄位中取出s_tr的個數
其思路是將s_tr從欄位中刪掉,並通過原欄位長度和修改後欄位的長度差值得到非零值。
但這得到的並不是個數,需要在除以待統計子字串的長度。
我們來統計一下au的個數:
SQL> select text,(length(text)-length(replace(text,'au','')))/length('au')
2 from user_source where name='P_TEST';
TEXT (LENGTH(TEXT)-LENGTH(REPLACE(T
-------------------------------------------------------------------------------- ------------------------------
procedure p_test is 0
begin 0
null; 0
--au 1
--default 1
--au default 2
--default au 2
--defaull 1
end ; 0
9 rows selected
那麼得到需要的結果,只需要在存在‘au’子字元時,比較‘au’和‘default’個數不等就行了。
SQL> select text,(length(text)-length(replace(text,'au','')))/length('au'),(length(text)-length(replace(text,'default','')))/length('default')
2 from user_source where name='P_TEST'
3 ;
TEXT (LENGTH(TEXT)-LENGTH(REPLACE(T (LENGTH(TEXT)-LENGTH(REPLACE(T
----------------------- ------------------------------ ------------------------------
procedure p_test is 0 0
begin 0 0
null; 0 0
--au 1 0
--default 1 1
--au default 2 1
--default au 2 1
--defaull 1 0
end ; 0 0
9 rows selected
結果如我們預期的那樣。
那麼得到想要的內容,語句為:
select text from (select text,(length(text)-length(replace(text,'au','')))/length('au') a,(length(text)-length(replace(text,'default','')))/length('default') b
from user_source where name='P_TEST') c
where c.a<>c.b;
或許還有更好的方法,以後討論。
寫sql,應該學會一種轉化,如本次思考中:
獲取特定子字串-》獲取子字串個數-》獲取子字串與所在字串的長度差
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26451536/viewspace-748698/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Ms Sql Server查詢儲存過程中的內容SQLServer儲存過程
- 理解索引(中):MySQL查詢過程和高階查詢索引MySql
- 在Linux中,如何使用grep命令查詢檔案中的內容?Linux
- 如何檢視Control File中儲存的內容
- 直播平臺原始碼,當內容超過視窗高度時,可以使用滾輪來檢視內容原始碼
- 如何使用SQL查詢檢視,Postico使用技巧分享~SQL
- MySQL慢查詢記錄原理和內容解析MySql
- MySQL 查詢的成本的檢視MySql
- 資訊保安檢查內容
- 安卓app中aar包檢視,可將.aar 字尾 重新命名為zip 可檢視內容安卓APP
- SQLServer查詢使用者儲存過程SQLServer儲存過程
- 檢視查詢報錯
- 【MySQL】檢視&子查詢MySql
- mysql使用KILL命令來終止特定的查詢程序MySql
- 一條select的查詢的過程
- git檢視檔案內容Git
- Centos7 中查詢檔案、目錄、內容CentOS
- oracle查詢語句查詢增加一列內容Oracle
- Linux中查詢指定內容所在行的常用命令!Linux
- 對於HTTP過程中POST內容加密的解決方案HTTP加密
- 檢視谷歌seo內容外掛谷歌
- git檢視指定提交檔案的內容Git
- 批次word文件內容查詢替換的方法
- ElasticSearch多層nested查詢、nested過濾排除非結果內容Elasticsearch
- python包和模組的內容整理Python
- npm包使用過程中遇到的坑,長期更~NPM
- MySQL學習 - 查詢的執行過程MySql
- Elasticsearch中的Term查詢和全文查詢Elasticsearch
- yum/dnf/rpm 等 檢視rpm 包安裝路徑 (fedora 中 pygtk 包內容安裝到哪裡了)
- OushuDB 檢視查詢執行情況
- 【PDB】Oracle跨PDB檢視查詢Oracle
- Bootstrap 包的內容boot
- 在modelsim中查詢指定訊號是否有特定值
- Linux 檢視檔案內容——bat 命令LinuxBAT
- 【SQL】Oracle查詢轉換之物化檢視查詢重寫SQLOracle
- centos vim怎麼查詢檔案內容CentOS
- Dynamics CRM 通過配置來設定查詢欄位的預設檢視
- es的查詢和過濾contextContext
- rpm包的查詢