性能測試常用Oracle語句


性能測試常用Oracle語句

顯示數據庫當前的連接數

select count(*) from v$process;

 

顯示數據庫最大連接數:

select value from v$parameter where name ='processes' 

 

修改最大Oracle最大連接數:

alter system set processes = 300 scope = spfile;

 

顯示當前的session連接數;

select count(*) fromv$session

 

查看當前有哪些用戶正在使用數據

SELECT osuser, a.username,cpu_time/executions/1000000||'s', sql_fulltext,machine from v$session a, v$sqlarea b where a.sql_address =b.address order by cpu_time/executions desc;

 

查看數據庫中SGA:

System global area (SGA),system global area(PGA);

 

查看連接oracle的所有機器的連接數

selectmachine,count(*) fromv$session groupbymachine;

查看連接oracle的所有機器的連接數和狀態

selectmachine,status,count(*) fromv$session groupbymachine,status orderbystatus;

 

Oracle 11g設置內存自動管理: 

ALTERSYSTEM SETMEMORY_TARGET = 1024M SCOPE=SPFILE;

ALTERSYSTEM SETmemory_max_target = 1500M SCOPE=SPFILE;

ALTERSYSTEM SETSGA_TARGET = 0 SCOPE=SPFILE;

ALTERSYSTEM SETSGA_MAX_SIZE=800M SCOPE=SPFILE;

ALTERSYSTEM SETPGA_AGGREGATE_TARGET = 0 SCOPE=SPFILE;

altersystem setpre_page_sga=FALSEscope=spfile;

 

查看消耗磁盤讀取最多的SQL Top 5:

select disk_reads,sql_text,SQL_FULLTEXT

from (select sql_text,disk_reads,SQL_FULLTEXT,

   dense_rank() over

     (order by disk_reads desc) disk_reads_rank

   from v$sql)

where disk_reads_rank <=5;

 

實例:

通過linux中消耗資源高的進程號獲取oracle消耗資源的sql語句:

1、linux中使用top命名查看oracle進程中消耗資源最高的進程號;

2、oracle中使用命令:

select c.spid,a.p1,a.p1raw,a.p2,a.event,b.sql_text,b.SQL_FULLTEXT,b.SQL_ID 

from v$session a,v$sql b,v$process c 

where a.wait_class<>'Idle' and a.sql_id=b.sql_id and a.PADDR=c.addr 

order by event;

3、查詢結果顯示出各個sql語句對應的進程號,從中找出top命令中對應消耗資源高的進程號即可找到相應的sql語句。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM