oracle的一些使用技巧1
1.使用建立臨時表
說明:wm_concat與listagg的差別
①wm_concat依賴wmsys使用者
②listagg是oracle11g2提供的函式
③listagg可以指定需要使用的分隔符,wm_concat不能指定,但是可以通過下面方式達到相同效果
listagg(ts.sid, '|') with group(order by ts.sid) as c_sid與
replace(wm_concat(ts.sid), ',', '|') as c_sid
參考連結:聚合函式listagg,wm_concat函式用法,listagg和wm_concat
(2)統計各班級的學生人數
1.找出無用索引: DML 效能低下,其中最嚴重的原因之一是無用索引的存在。所有SQL的插入,更新和刪除操作在它們需要在每一行資料被改變時修改大量索引的時候會變得更慢。許多Oracle 管理人員只要看見在一個SQL 查詢的WHERE語句出現了一列的話就會為它分配索引。雖然這個方法能夠讓SQL執行得更快速,但是基於功能的Oracle 索引使得資料庫管理人員有可能在資料表的行上過度分配索引。過度分配索引會嚴重影響關鍵Oracle 資料表的效能。 在Oracle9i出現以前,沒有辦法確定SQL查詢沒有使用的索引。Oracle9i有一個工具能夠讓你使用ALTER INDEX命令監視索引的使用。然後你可以查詢這些沒有使用的索引並從資料庫裡刪除它們。 下面是一段指令碼,它能夠開啟一個系統中所有索引的監視功能: spool run_monitor.sql select 'alter index '||owner||'.'||index_name||' monitoring usage;' from dba_indexes where owner not in ('SYS','SYSTEM'); spool off; @run_monitor 你需要等待一段時間直到在資料庫上運行了足夠多的SQL語句以後,然後你就可以查詢新的V$OBJECT_USAGE檢視。 select index_name,table_name,mon,used from v$object_usage; 在下面,我們可以看見V$OBJECT_USAGE有一列被稱作USED,它的值是YES或者NO。它不會告訴你Oracle使用了這個索引多少次,但是這個工具對於找出沒有使用的索引還是很有用的。 SQL> select * from v$object_usage where rownum < 10; INDEX_NAME TABLE_NAME MONITORING USED START_MONITORING END_MONITORING ------------------------------ ------------------------------ ---------- ---- ------------------- ------------------- ASD DIM_ACCT_ITEM_TYPE_TEMP YES NO 01/15/2004 13:50:59 IDX_ACCOUNT_ACCESSORY_TARIFF1 ACCOUNT_ACCESSORY_TARIFF YES NO 01/15/2004 13:50:59 IDX_ACCOUNT_QUOTA_LOG1 ACCOUNT_QUOTA_LOG YES NO 01/15/2004 13:50:59 IDX_ACCOUNT_SYSTEM_PARAMETERS1 ACCOUNT_SYSTEM_PARAMETERS YES NO 01/15/2004 13:50:59 IDX_ACCT2 ACCT YES NO 01/15/2004 13:50:59 IDX_ACCT3 ACCT YES NO 01/15/2004 13:51:00 IDX_ACCT4 ACCT YES NO 01/15/2004 13:51:00 IDX_ACCT_BIND_DISCT1 ACCT_BIND_DISCT YES NO 01/15/2004 13:51:00 IDX_ACCT_BIND_DISCT2 ACCT_BIND_DISCT YES NO 01/15/2004 13:51:00 2.檢視一個很長的操作已經做了多少: