性能測試經常使用Oracle語句linux
顯示數據庫當前的鏈接數sql
select count(*) from v$process;數據庫
顯示數據庫最大鏈接數:session
select value from v$parameter where name ='processes' oracle
修改最大Oracle最大鏈接數:性能
alter system set processes = 300 scope = spfile;測試
顯示當前的session鏈接數;spa
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語句:
一、linux中使用top命名查看oracle進程中消耗資源最高的進程號;
二、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;
三、查詢結果顯示出各個sql語句對應的進程號,從中找出top命令中對應消耗資源高的進程號便可找到相應的sql語句。