oracle学习笔记

来源:互联网 发布:sql 触发器 更新时间 编辑:程序博客网 时间:2024/04/27 20:40
 
oracle学习笔记

DBA
管理

1
2、启动关闭数据库
  关闭:
   svrmgr>connect internal/oracle
         >shutdown   --正常关闭数据库
   svrmgr>shutdown  immediate  --立即关闭数据库
   svrmgr>shutdown abort  --一种最直接的关闭数据库的方式,执行之后,重新启动需要花6-8小时
  启动:
   svrmgr>startup  --正常启动
         --等价于:startup nomount;
                  alter database  mount;
                  alter database  open;
   svrmgr>startup mount; --安装启动:用于改变数据库的归档或执行恢复状态
   svrmgr>startup nomount;  --用于重建控制文件或重建数据库
   svrmgr>startup  restrict; --约束启动,能启动数据库,但只允许具有一定特权的用户访问
   如果希望改变这种状态,连接成功后
     alter system disable restricted session;
   svrmgr>startup force;当不能关闭数据库时,可采用强制启动数据库来完成数据库的关闭操作。
   svrmgr>startup pfile=d:/orant/database/initorcl.ora  --带初始化参数文件的启动
3、缺省用户和密码
 <1>. Oracle安裝完成后的初始口令? 
   internal/oracle 
  sys/change_on_install 
  system/manager 
  scott/tiger 
  sysman/oem_temp
 <2>. ORACLE9IAS WEB CACHE的初始默认用户和密码? 
   administrator/administrator
4、让定义自己的回滚段生效
  在initorcl.ora中加入rollback_segments=(rb0,rb1,...)
  其中rb0,rb1为自己定义的回滚段,可使这些回滚段在启动时生效
5、查看修改数据库的字符集
<1>数据库服务器字符集 
   在表props$中
   update props$ set value$='ZHS16CGB231280' 
     where name ='NLS_CHARACTERSET'
   然后重新启动数据库,而不需要重新安装
   8i以上版本可以通过alter database来修改字符集,但也只限于子集到超集,不建议修改props$表,将可能导致严重错误。
Startup nomount;
Alter database mount exclusive;
Alter system enable restricted session;
Alter system set job_queue_process=0;
Alter database open;
Alter database character set zhs16gbk;
   
   
   sql> show parameter NLS
   查看数据库字符集:
 SELECT *  FROM NLS_DATABASE_PARAMETERS; 
 SELECT *  FROM V$NLS_PARAMETERS;
<2>
客户端字符集环境select * from nls_instance_parameters,其来源于v$parameter,
表示客户端的字符集的设置,可能是参数文件,环境变量或者是注册表
会话字符集环境 select * from nls_session_parameters,其来源于v$nls_parameters,表示会话自己的设置,可能是会话的环境变量或者是alter session完成,如果会话没有特殊的设置,将与nls_instance_parameters一致。
客户端的字符集要求与服务器一致,才能正确显示数据库的非Ascii字符。如果多个设置存在的时候,alter session>环境变量>注册表>参数文件
字符集要求一致,但是语言设置却可以不同,语言设置建议用英文。如字符集是zhs16gbk,则nls_lang可以是American_America.zhs16gbk。

<3> 
有时候用crontab发起的时候,由于执行的shell脚本的不同,导致很多的环境变量不同。常常看到插入到数据库中的汉字变成乱码。
    比如shell脚本cai.sh如下内容。
#!/bin/ksh
export ORACLE_BASE=/u01/oracle/app/oracle
export ORACLE_HOME=$/product/9.2.0
export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATH
export SHLIB_PATH=$ORACLE_HOME/lib32:$ORACLE_HOME/rdbms/lib32:/app/prepay/lib
/u01/oracle/app/oracle/product/9.2.0/bin/sqlplus aicbs/aicbs@busi_cs <insert into okcai values('okcai是个大好人呀');
commit;
quit
!
在crontab中定时每天20:19执行一次
19 20 * * * /bin/sh /app/prepay/cai.sh >/dev/null 2>&1 &
则可以看到数据库中数据变成了:
2LQSJY
当前数据库的字符集是
SELECT *  FROM NLS_DATABASE_PARAMETERS
AMERICAN.ZHS16GBK
为了正常,必须保持客户端和数据库一致的字符集
改脚本如下即可
#!/bin/ksh
export ORACLE_BASE=/u01/oracle/app/oracle
export ORACLE_HOME=$/product/9.2.0
export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATH
export SHLIB_PATH=$ORACLE_HOME/lib32:$ORACLE_HOME/rdbms/lib32:/app/prepay/lib
####下面就是增加的
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
/u01/oracle/app/oracle/product/9.2.0/bin/sqlplus aicbs/aicbs@busi_cs <insert into okcai values('okcai是个大好人呀');
commit;
quit
!

6
、svgmgr>show sga
7、查询锁的原因
   如果进程被死锁,可以按下面方式查询
 <1> 从v$session或者v$locked_object找到此session
 <2> 如果有lockwait,查询v$lock,
    select * from v$lock where kaddr = 'C00000024AB87210'
     如果没有,根据sid
     select * from v$lock where sid = 438
 <3> 查看v$lock
     lmode > 0,表示已经得到此锁
     request > 0 表示正在请求此锁
     根据id1和id2的值可以判断请求哪个锁的释放。
     select * from v$lock where id1=134132 and id2 = 31431 
8. 查询锁的状况的对象
 V$LOCK,  V$LOCKED_OBJECT,  V$SESSION,  V$SQLAREA,  V$PROCESS ;
   查询锁的表的方法:
SELECT S.SID SESSION_ID, S.USERNAME, 
DECODE(LMODE, 0, 'None', 1, 'Null', 2, 'Row-S (SS)', 3, 'Row-X (SX)', 4, 'Share', 5, 'S/Row-X (SSX)', 6, 'Exclusive', TO_CHAR(LMODE)) MODE_HELD, 
DECODE(REQUEST, 0, 'None', 1, 'Null', 2, 'Row-S (SS)', 3, 'Row-X (SX)', 4, 'Share', 5, 'S/Row-X (SSX)', 6, 'Exclusive', TO_CHAR(REQUEST)) MODE_REQUESTED, 
O.OWNER||'.'||O.OBJECT_NAME||' ('||O.OBJECT_TYPE||')', S.TYPE LOCK_TYPE, L.ID1 LOCK_ID1, L.ID2 LOCK_ID2 
FROM V$LOCK L, SYS.DBA_OBJECTS O, V$SESSION S 
WHERE L.SID = S.SID AND L.ID1 = O.OBJECT_ID ;
9. 怎样查得数据库的SID ?
select name from v$database; 
也可以直接查看 init.ora文件
10、管理回滚段:
    存放事务的恢复信息
    建立回滚段
      create public  rollback segment SEG_NAME  tabelspace TABLESPACE_NAME;
      alter   rollback segment SEG_NAME  online;
    删除回滚段
      首先改变为offline状态
    直接使用回滚段
    sql>set transaction  use  rollback  segment  SEG_NAME;
11. 计算一个表占用的空间的大小
select owner,table_name, 
NUM_ROWS,
BLOCKS*AAA/1024/1024 "Size M", 
EMPTY_BLOCKS, 
LAST_ANALYZED 
from dba_tables 
where table_name='XXX'; 
Here: AAA is the value of db_block_size ; 
XXX is the table name you want to check

12. 
表在表空间中的存储情况
   select segment_name,sum(bytes),count(*) ext_quan from dba_extents where 
   tablespace_name='&tablespace_name' and segment_type='TABLE' group by       tablespace_name,segment_name; 
13. 索引在表空间中的存储情况
   select segment_name,count(*) from dba_extents where segment_type='INDEX' and       owner='&owner' 
   group by segment_name; 
14.查看某表/索引的大小
 表
     SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments 
         where segment_name=upper('&table_name');
       索引
     SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments 
         where segment_name=upper('&index_name');
15、确定可用空间
    select tablespace_name,sum(blocks),sum(bytes) from sys.dba_free_space group by tablespace_name;
16、程序中报错:maxinum cursor exceed!
  <1> 查看当前的open cursor参数
   sql> show parameter open_cursors
  <2> 如果确实很小,应该调整数据库初始化文件
   加如一项  open_cursors=200
  <3> 如果很大,则
select sid,sql_text,count(*) from v$open_cursor
group by sid,sql_text
having count(*) > 200 
 其中200是随便写一个比较大的值。查询得到打开太多的cursor.
17、查看数据库的版本信息
SQL> select  * from v$version;
包含版本信息,核心版本信息,位数信息(32位或64位)等
至于位数信息,在linux/unix平台上,可以通过file查看,如
file $ORACLE_HOME/bin/oracle
18. 查看最大会话数
 SELECT * FROM V$PARAMETER WHERE NAME LIKE 'proc%'; 
 SQL> 
 SQL> show parameter processes 
 NAME TYPE VALUE 
 ------------------------------------ ------- ------------------------------ 
 aq_tm_processes integer 1 
 db_writer_processes integer 1 
 job_queue_processes integer 4 
 log_archive_max_processes integer 1 
 processes integer 200 
 
 这里为200个用户。 
 select * from v$license; 
 
其中sessions_highwater纪录曾经到达的最大会话数 
19. 以archivelog的方式运行oracle。 
init.ora 
log_archive_start = true 
RESTART DATABASE
20. unix 下调整数据库的时间
su -root 
date -u 08010000
21.P4电脑的安裝方法 
 将SYMCJIT.DLL改为SYSMCJIT.OLD
22. 如何查询SERVER是不是OPS? 
SELECT *  FROM V$OPTION; 
如果PARALLEL SERVER=TRUE则有OPS能
23. 查询每个用户的权限
SELECT *  FROM DBA_SYS_PRIVS;
24.将表/索引移动表空间
ALTER TABLE TABLE_NAME MOVE TABLESPACE_NAME;
ALTER INDEX INDEX_NAME REBUILD TABLESPACE TABLESPACE_NAME;
25.在LINUX,UNIX下启动DBA STUDIO?
OEMAPP  DBASTUDIO
26.LINUX下查询磁盘竞争状况命令? 
Sar  -d
27.LINUX下查询磁盘CPU竞争状况命令? 
sar   -r
28. 查询表空间信息? 
SELECT *  FROM  DBA_DATA_FILES;
29. 看各个表空间占用磁盘情况:
SQL> col tablespace format a20
      SQL> select 
      b.file_id                                                          
文件ID号,
      b.tablespace_name                                                     表空间名,
      b.bytes                                                           字节数,
      (b.bytes-sum(nvl(a.bytes,0)))                        已使用,
      sum(nvl(a.bytes,0))                                                     剩余空间,
      sum(nvl(a.bytes,0))/(b.bytes)*100                     剩余百分比 
      from dba_free_space a,dba_data_files b 
      where a.file_id=b.file_id 
      group by b.tablespace_name,b.file_id,b.bytes 
      order by b.file_id
 
30. 如把ORACLE设置为MTS或专用模式? 
#dispatchers="(PROTOCOL=TCP) (SERVICE=SIDXDB)" 
加上就是MTS,注释就是专用模式,SID是指你的实例名。 
31. 如何才能得知系统当前的SCN号 ?
select max(ktuxescnw * power(2, 32) + ktuxescnb) from x$ktuxe;

32. 
修改oracel数据库的默认日期
 alter session set nls_date_format='yyyymmddhh24miss';
   OR 
 可以在init.ora中加上一行 
 nls_date_format='yyyymmddhh24miss' 
33. 将小表放入keep池中
alter table xxx storage(buffer_pool keep); 
34. 如何检查是否安装了某个patch? 
 check that  oraInventory 
35. 如何修改oracle数据库的用户连接数? 
修改initSID.ora,将process加大,重启数据库. 
36. 如何创建SPFILE?
SQL> connect / as sysdba 
 SQL> select * from v$version; 
 SQL> create pfile from spfile; 
SQL> CREATE SPFILE FROM PFILE='E:/ora9i/admin/eygle/pfile/init.ora'; 
文件已创建。 
SQL> CREATE SPFILE='E:/ora9i/database/SPFILEEYGLE.ORA' FROM PFILE='E:/ora9i/admin/eygle/pfile/init.ora'; 
文件已创建。 

37. 
內核参数的应用
    shmmax
  含义:这个设置并不决定究竟Oracle数据库或者操作系统使用多少物理内存,只决定了最多可以使用的内存数目。这个设置也不影响操作系统的内核资源。 
  设置方法:0.5*物理内存 
  例子:Set shmsys:shminfo_shmmax=10485760 
  shmmin 
  含义:共享内存的最小大小。 
  设置方法:一般都设置成为1。 
  例子:Set shmsys:shminfo_shmmin=1: 
  shmmni 
  含义:系统中共享内存段的最大个数。 
  例子:Set shmsys:shminfo_shmmni=100 
  shmseg 
  含义:每个用户进程可以使用的最多的共享内存段的数目。 
  例子:Set shmsys:shminfo_shmseg=20: 
  semmni 
  含义:系统中semaphore identifierer的最大个数。 
  设置方法:把这个变量的值设置为这个系统上的所有Oracle的实例的init.ora中的最大的那个processes的那个值加10。 
  例子:Set semsys:seminfo_semmni=100 
  semmns 
  含义:系统中emaphores的最大个数。 
  设置方法:这个值可以通过以下方式计算得到:各个Oracle实例的initSID.ora里边的processes的值的总和(除去最大的Processes参数)+最大的那个Processes×2+10×Oracle实例的个数。 
  例子:Set semsys:seminfo_semmns=200 
  semmsl: 
  含义:一个set中semaphore的最大个数。 
  设置方法:设置成为10+所有Oracle实例的InitSID.ora中最大的Processes的值。 
  例子:Set semsys:seminfo_semmsl=-200
38. 怎样查看哪些用户拥有SYSDBA、SYSOPER权限? 
SQL>conn sys/change_on_install
SQL>select * from V_$PWFILE_USERS;

  
39. 
如何查看数据文件放置的路径 ? 
col file_name format a50
SQL> select tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_files order by file_id; 
40. 如何查看现有回滚段及其状态 ? 
SQL> col segment format a30
SQL> SELECT SEGMENT_NAME,OWNER,TABLESPACE_NAME,SEGMENT_ID,FILE_ID,STATUS FROM DBA_ROLLBACK_SEGS 

41. Oracle
常用系统文件有哪些? 
通过以下视图显示这些文件信息:v$database,v$datafile,v$logfile v$controlfile v$parameter; 
42.查看数据库实例
SQL>SELECT * FROM V$INSTANCE; 
43. 怎样估算SQL执行的I/O数 ? 
SQL>SET AUTOTRACE ON ; 
SQL>SELECT * FROM TABLE; 
OR 
SQL>SELECT *  FROM  v$filestat ; 
可以查看IO数 
44. 怎样扩大REDO LOG的大小? 
建立一个临时的redolog组,然后切换日志,删除以前的日志,建立新的日志。 

45. 
查询做比较大的排序的进程?
   <1>
   SELECT b.tablespace, b.segfile#, b.segblk#, b.blocks, a.sid, a.serial#, 
   a.username, a.osuser, a.status 
   FROM v$session a,v$sort_usage b 
   WHERE a.saddr = b.session_addr 
   ORDER BY b.tablespace, b.segfile#, b.segblk#, b.blocks ;
  <2>. 查询做比较大的排序的进程的SQL语句
   select /*+ ORDERED */ sql_text from v$sqltext a 
   where a.hash_value = ( 
   select sql_hash_value from v$session b 
   where b.sid = &sid and b.serial# = &serial) 
   order by piece asc ;
46. ORA-01555 SNAPSHOT TOO OLD的解决办法
   增加MINEXTENTS的值,增加区的大小,设置一个高的OPTIMAL值。 
   如果是执行大的事务,报此错误,说明oracle给此事务随机分配的回滚段太小了,这时可以为它指定一个足够大的回滚段,以确保这个事务的成功执行.例如 
set transaction use rollback segment roll_abc; 
delete from table_name where ... 
commit; 
  回滚段roll_abc被指定给这个delete事务,commit命令则在事务结束之后取消了回滚段的指定. 

47. 
事务要求的回滚段空间不够,表现为表空间用满(ORA-01560错误),回滚段扩展到达参数      MAXEXTENTS的值(ORA-01628)的解决办法.
   向回滚段表空间添加文件或使已有的文件变大;增加MAXEXTENTS的值。 
    
48. 
监控事例的等待
   select event,sum(decode(wait_Time,0,0,1)) "Prev", 
   sum(decode(wait_Time,0,1,0)) "Curr",count(*) "Tot" 
   from v$session_Wait 
   group by event order by 4; 
49. 回滚段的争用情况
   select name, waits, gets, waits/gets "Ratio" 
   from v$rollstat C, v$rollname D 
   where C.usn = D.usn; 
50 监控表空间的 I/O 比例
   select B.tablespace_name name,B.file_name "file",A.phyrds pyr, 
   A.phyblkrd pbr,A.phywrts pyw, A.phyblkwrt pbw 
   from v$filestat A, dba_data_files B 
   where A.file# = B.file_id 
   order by B.tablespace_name; 
51、监控文件系统的 I/O 比例
   select substr(C.file#,1,2) "#", substr(C.name,1,30) "Name", 
   C.status, C.bytes, D.phyrds, D.phywrts 
   from v$datafile C, v$filestat D 
   where C.file# = D.file#; 
52、监控 SGA 的命中率
   select a.value + b.value "logical_reads", c.value "phys_reads", 
   round(100 * ((a.value+b.value)-c.value) / (a.value+b.value)) "BUFFER HIT RATIO" 
   from v$sysstat a, v$sysstat b, v$sysstat c 
   where a.statistic# = 38 and b.statistic# = 39 
   and c.statistic# = 40; 
53、监控 SGA 中字典缓冲区的命中率
   select parameter, gets,Getmisses , getmisses/(gets+getmisses)*100 "miss ratio", 
   (1-(sum(getmisses)/ (sum(gets)+sum(getmisses))))*100 "Hit ratio" 
   from v$rowcache 
   where gets+getmisses <>0 
   group by parameter, gets, getmisses; 
54、监控 SGA 中共享缓存区的命中率,应该小于1% 
   select sum(pins) "Total Pins", sum(reloads) "Total Reloads", 
   sum(reloads)/sum(pins) *100 libcache 
   from v$librarycache; 
   select sum(pinhits-reloads)/sum(pins) "hit radio",sum(reloads)/sum(pins)    "reload percent" 
   from v$librarycache; 
55、显示所有数据库对象的类别和大小
   select count(name) num_instances ,type ,sum(source_size) source_size , 
   sum(parsed_size) parsed_size ,sum(code_size) code_size ,sum(error_size)    error_size, 
   sum(source_size) +sum(parsed_size) +sum(code_size) +sum(error_size)    size_required 
   from dba_object_size 
   group by type order by 2; 
56、监控 SGA 中重做日志缓存区的命中率,应该小于1% 
   SELECT name, gets, misses, immediate_gets, immediate_misses, 
   Decode(gets,0,0,misses/gets*100) ratio1, 
   Decode(immediate_gets+immediate_misses,0,0, 
   immediate_misses/(immediate_gets+immediate_misses)*100) ratio2 
   FROM v$latch WHERE name IN ('redo allocation', 'redo copy'); 
57、监控内存和硬盘的排序比率,最好使它小于 .10,增加 sort_area_size 
   SELECT name, value FROM v$sysstat WHERE name IN ('sorts (memory)', 'sorts      (disk)'); 

58
、监控当前数据库谁在运行什么SQL语句?
   SELECT osuser, username, sql_text from v$session a, v$sqltext b 
   where a.sql_address =b.address order by address, piece; 
59、监控字典缓冲区?
   SELECT (SUM(PINS - RELOADS)) / SUM(PINS) "LIB CACHE" FROM V$LIBRARYCACHE; 
   SELECT (SUM(GETS - GETMISSES - USAGE - FIXED)) / SUM(GETS) "ROW CACHE" FROM    V$ROWCACHE; 
   SELECT SUM(PINS) "EXECUTIONS", SUM(RELOADS) "CACHE MISSES WHILE EXECUTING" FROM    V$LIBRARYCACHE; 
   后者除以前者,此比率小于1%,接近0%为好。 
   SELECT SUM(GETS) "DICTIONARY GETS",SUM(GETMISSES) "DICTIONARY CACHE GET MISSES" 
   FROM V$ROWCACHE 

60
、监控 MTS 
   select busy/(busy+idle) "shared servers busy" from v$dispatcher; 
   此值大于0.5时,参数需加大 
   select sum(wait)/sum(totalq) "dispatcher waits" from v$queue where    type='dispatcher'; 
   select count(*) from v$dispatcher; 
   select servers_highwater from v$mts; 
   servers_highwater接近mts_max_servers时,参数需加大 

61
、查看碎片程度高的表? 
   SELECT segment_name table_name , COUNT(*) extents 
   FROM dba_segments WHERE owner NOT IN ('SYS', 'SYSTEM') GROUP BY segment_name 
   HAVING COUNT(*) = (SELECT MAX( COUNT(*) ) FROM dba_segments GROUP BY       segment_name); 

62
、如何知道使用CPU多的用户session? 
   11是cpu used by this session 
   select a.sid,spid,status,substr(a.program,1,40)       prog,a.terminal,osuser,value/60/100 value 
   from v$session a,v$process b,v$sesstat c 
   where c.statistic#=11 and c.sid=a.sid and a.paddr=b.addr order by value desc; 

63.
如何检查操作系统是否存在IO的问题
 使用的工具有sar,这是一个比较通用的工具。
 #sar -u 2 10
 即每隔2秒检察一次,共执行20次,当然这些都由你决定了。
    示例返回:
    HP-UX hpn2 B.11.00 U 9000/800    08/05/03
    18:26:32    %usr    %sys    %wio   %idle
    18:26:34      80       9      12       0
    18:26:36      78      11      11       0
    18:26:38      78       9      13       1
    18:26:40      81      10       9       1
    18:26:42      75      10      14       0
    18:26:44      76       8      15       0
    18:26:46      80       9      10       1
    18:26:48      78      11      11       0
    18:26:50      79      10      10       0
    18:26:52      81      10       9       0
    
    Average       79      10      11       0
 其中的%usr指的是用户进程使用的cpu资源的百分比,
 %sys指的是系统资源使用cpu资源的百分比,
 %wio指的是等待io完成的百分比,这是值得我们观注的一项,
 %idle即空闲的百分比。如果wio列的值很大,如在35%以上,说明你的系统的IO存在瓶颈,你的CPU花费了很大的时间去等待IO的完成。
 Idle很小说明系统CPU很忙。像我的这个示例,可以看到wio平均值为11说明io没什么特别的问题,而我的idle值为零,说明我的cpu已经满负荷运行了。
64.关注一下内存。
 常用的工具便是vmstat,对于hp-unix来说可以用glance,Aix来说可以用topas,当你发现vmstat中pi列非零,memory中的free列的值很小,glance,topas中内存的利用率多于80%时,这时说明你的内存方面应该调节一下了,方法大体有以下几项。
  a.划给Oracle使用的内存不要超过系统内存的1/2,一般保在系统内存的40%为益。
  b.为系统增加内存
  c.如果你的连接特别多,可以使用MTS的方式
  d.打全补丁,防止内存漏洞。
65、查找前十条性能差的sql.
 SELECT * FROM 
  (
   SELECT PARSING_USER_ID
          EXECUTIONS,
          SORTS,
          COMMAND_TYPE,
          DISK_READS,
          sql_text
      FROM  v$sqlarea
     ORDER BY disk_reads DESC 
   )  
  WHERE ROWNUM<10 ;
66、查看占io较大的正在运行的session
 SELECT se.sid,
       se.serial#,
       pr.SPID,
       se.username,
       se.status,
       se.terminal,
       se.program,
       se.MODULE,
       se.sql_address,
       st.event,
       st.p1text,
       si.physical_reads,
       si.block_changes 
  FROM v$session se,
       v$session_wait st,
       v$sess_io si,
       v$process pr
 WHERE st.sid=se.sid 
   AND st.sid=si.sid
   AND se.PADDR=pr.ADDR
   AND se.sid>6
   AND st.wait_time=0 
   AND st.event NOT LIKE '%SQL%'
 ORDER BY physical_reads DESC
对检索出的结果的几点说明:
 <1> 我是按每个正在等待的session已经发生的物理读排的序,因为它与实际的IO相关。
 <2> 你可以看一下这些等待的进程都在忙什么,语句是否合理?
  Select sql_address from v$session where sid=;
  Select * from v$sqltext where address=;
 执行以上两个语句便可以得到这个session的语句。
 你也以用alter system kill session 'sid,serial#';把这个session杀掉。
 <3> 应观注一下event这列,这是我们调优的关键一列,下面对常出现的event做以简要的说明:
    a、buffer busy waits,free buffer waits这两个参数所标识是dbwr是否够用的问题,与IO很大相关的,当v$session_wait中的free buffer wait的条目很小或没有的时侯,说明你的系统的dbwr进程决对够用,不用调整;free buffer wait的条目很多,你的系统感觉起来一定很慢,这时说明你的dbwr已经不够用了,它产生的wio已经成为你的数据库性能的瓶颈,这时的解决办法如下:
 a.1增加写进程,同时要调整db_block_lru_latches参数
     示例:修改或添加如下两个参数
      db_writer_processes=4
    db_block_lru_latches=8
 a.2开异步IO,IBM这方面简单得多,hp则麻烦一些,可以与Hp工程师联系。
    b、db file sequential read,指的是顺序读,即全表扫描,这也是我们应该尽量减少的部分,解决方法就是使用索引、sql调优,同时可以增大db_file_multiblock_read_count这个参数。
    c、db file scattered read,这个参数指的是通过索引来读取,同样可以通过增加db_file_multiblock_read_count这个参数来提高性能。
    d、latch free,与栓相关的了,需要专门调节。
    e、其他参数可以不特别观注。

67. 
文件说明
 <1>监听器日志文件
   以8I为例
   $ORACLE_HOME/NETWORK/LOG/LISTENER.LOG
 <2>. 监听器参数文件
   以8I为例
   $ORACLE_HOME/NETWORK/ADMIN/LISTENER.ORA
 <3>. TNS 连接文件
   以8I为例
   $ORACLE_HOME/NETWORK/ADMIN/TNSNAMES.ORA
 <4>. Sql*Net 环境文件
   以8I为例
   $ORACLE_HOME/NETWORK/ADMIN/SQLNET.ORA
 <5>. 警告日志文件
   以8I为例
   $ORACLE_HOME/ADMIN/SID/BDUMP/SIDALRT.LOG
 <6>. 基本结构
   以8I为例
   $ORACLE_HOME/RDBMS/ADMIN/STANDARD.SQL
 <7>. 建立数据字典视图
   以8I为例
   $ORACLE_HOME/RDBMS/ADMIN/CATALOG.SQL
 <8>.建立审计用数据字典视图
   以8I为例
   $ORACLE_HOME/RDBMS/ADMIN/CATAUDIT.SQL
 <9>. 建立快照用数据字典视图
   以8I为例
   $ORACLE_HOME/RDBMS/ADMIN/CATSNAP.SQL
68、oracle 安全与审计
   user_sys_privs,user_tab_privs;
配置文件
   主要参数
   session_per_user  每个用户可同时进行几个会话
   cpu_per_session   每个用户可用多少个(cpu的)百分之一秒
   cpu_per_call      语法分析、执行、取数可用多少个百分之一秒
   connect_time      用户连接数据库的时间(分钟)
   idle_time         用户不调用数据库的时间(分钟)
   logical_reads_per_session  整个会话过程中用户访问oracle的块数
   logical_reads_per_call     一次调用用户访问oracle的块数
   private_SGA       一个用户进程所用SGA的内存数量
   composite_limit   复合限制数
   failed_login_attempts 连续多次注册失败引起一个帐户死锁
   password_life_time    一个口令在其终止前可用的天数
   password_reuse_time    一个口令在其n天才能重新使用
   password_reuse_max    一个口令在重新使用之前必须改变多少次
   password_lock_time    一个口令帐户被锁住的天数
69、管理初始化文件
   show parameters
   经常修改的项目有  v$parameter
   shared_pool_size  分配给共享的字节数
   rollback_segments 回滚段的个数
   sessions          会话个数
   processes         进程个数
70、管理控制文件
    控制文件保存文件有关数据库创建时间、数据库名以及数据库运行时使用的所有文件位置和名称。
    增加控制文件,在initorcl.ora中,找到control_file项,增加一项即可
    删除控制文件,在initorcl.ora中去掉,然后删除物理文件
    建立新的控制文件
    create controlfile  [reuse] [set] database  数据库名  
        logfile [group 整数] 文件名 [,[group 整数] 文件名],...
    对于现有的数据库,可以间接地通过
    alter database backup  controlfile  to trace命令生成控制文件,即可在/orant/rmb73/trace
    下有ora00289.trc文件,其内容为文本
71、日志管理 
    <1>建立日志组
    sql>select * from v$logfile;
    sql>alter database add logfile group 3
        ('f:/orant/database/log1_g3.ora'
         'f:/orant/database/log2_g3.ora') size 100k;
    sql>select * from v$logfile;
 ----
 sql> alter database add logfile group 4
  ('/disk3/log4a.rdo','/disk4/log4b.rdo') size 1m; 

    <2>
删除日志组
      alter database  drop logfile group 1;
      但是其物理文件并没有被删除掉
        系统至少需要2个日志组,如果只有2个,就不能删除
        不能删除正活动的日志组
    <3>手工归档
      通过alter system 的archive log 子句来实现
          archive  log [thread 整数]
          [seq 整数][change 整数][current][group 整数]
          [logfile '文件名'][next][all][start][to '位置']
   <4> 强制日志切换 
 sql> alter system switch logfile;
   <5> 强制checkpoints 
        sql> alter system checkpoint; 
   <6> adding online redo log members 
 sql>alter database add logfile member 
     '/disk3/log1b.rdo' to group 1, 
     '/disk4/log2b.rdo' to group 2; 
   <7>.changes the name of the online redo logfile 
 sql> alter database rename file 'c:/oracle/oradata/oradb/redo01.log' 
  to 'c:/oracle/oradata/redo01.log'; 
   <8> drop online redo log members 
 sql> alter database drop logfile member 'c:/oracle/oradata/redo01.log'; 
   <9>.clearing online redo log files 
 sql> alter database clear [unarchived] logfile 'c:/oracle/log2a.rdo'; 
   <10>.using logminer analyzing redo logfiles 
 a. in the init.ora specify utl_file_dir = ' ' 
 b. sql> execute dbms_logmnr_d.build('oradb.ora','c:/oracle/oradb/log'); 
 c. sql> execute dbms_logmnr_add_logfile('c:/oracle/oradata/oradb/redo01.log', 
    sql> dbms_logmnr.new); 
 d. sql> execute dbms_logmnr.add_logfile('c:/oracle/oradata/oradb/redo02.log', 
    sql> dbms_logmnr.addfile); 
 e. sql> execute dbms_logmnr.start_logmnr(dictfilename=>'c:/oracle/oradb/log/oradb.ora'); 
 f. sql> select * from v$logmnr_contents(v$logmnr_dictionary,v$logmnr_parameters 
    sql> v$logmnr_logs); 
 g. sql> execute dbms_logmnr.end_logmnr; 

72 
系统控制
   alter system ...
   
   alter system enable restricted session;  只允许具有restricted系统特权的用户登录
   alter system flush  shared_pool  清除共享池
   alter system checkpoint   执行一 个检查点
   alter system set license_max_session=64,license_session_warning=54 会话限制为64,会话的警界为54
   alter system set license_max_session=0 会话数为无限制
   alter system set license_max_users=300 用户限制为300个
   alter system switch logfile  强制执行日志转换
73 会话控制
   alter session 
   
   alter session set sql_trace=true  当前会话具有sql跟踪功能
   alter session set NLS_language=French 出错信息设为法语
   alter session set NLS_date_format='YYYY MM DD HH24:MI:SS';缺省日期格式
   alter session set optimizier_goal=first_row改变优化方法为基于开销方法,具有快速响应速度
   update student@teach set sold=sold+1 where sno='98010';
   commit;
   alter session close database link teach; 关闭远程链路
74、封锁机制
   数据封锁:保护表数据,在多个用户并行存取数据时候,保证数据的完整性。
   DML操作又在两个级别获取数据封锁:指定记录封锁和表封锁
   表封锁可以有下列方式:行共享(RS),行排他(RX),共享封锁(S),共享行排他(SPX)和排他
   封锁(X)
   行共享表封锁(RS),允许其他事务并行查询、插入,修改和删除及再行封锁
   select ...from  表名  ...  for update of ...;
   lock table 表名  in row share mode;
   行排他表封锁(RX) 对该行有独占权利
   insert into 表名 ...;
   update 表名 ...;
   delete from 表名 ...;
   lock table 表名 in row exclusive mode;
   允许并行查询、插入、删除或封锁其他行,但禁止其他事务使用下列命令进行并发封锁:
     lock table 表名 in share mode;
     lock table 表名 in share exclusive mode;
     lock table 表名 in exclusive mode;
   共享表封锁(S)
     lock table 表名 in share mode;
     允许其他事务可在该表上做查询和再实现共享表操作,但不能修改该表,同时也不能做如下封锁:
       lock table 表名 in share row exclusive mode;
       lock table 表名 in  exclusive  mode;
       lock table 表名 in row exclusive mode;
   共享排他表封锁(SRX)
      lock table 表名 in share row exclusive mode;
   排他表封锁(SRX)
      lock table 表名 in  exclusive mode;   

75
、设置事务
   set transaction [read only][read write][use rollback segment 回滚段名]
76.如果希望用aimtzmcc用户连接数据库,访问aicbs用户的表,不在表名前缀"aicbs.",可以在建立数据库连接后发下面的命令
           alter session set current_schema = aicbs;
77、表空间管理 
    <1> 创建表空间
 sql> create tablespace tablespace_name datafile 'c:/oracle/oradata/file1.dbf' size 100m, 
 sql> 'c:/oracle/oradata/file2.dbf' size 100m minimum extent 550k [logging/nologging] 
 sql> default storage (initial 500k next 500k maxextents 500 pctinccease 0) 
 sql> [online/offline] [permanent/temporary] [extent_management_clause] 
    <2>.locally managed tablespace 
 sql> create tablespace user_data datafile 'c:/oracle/oradata/user_data01.dbf' 
 sql> size 500m extent management local uniform size 10m; 
    <3>.temporary tablespace 
 sql> create temporary tablespace temp tempfile 'c:/oracle/oradata/temp01.dbf' 
 sql> size 500m extent management local uniform size 10m; 
    <4>.change the storage setting 
 sql> alter tablespace app_data minimum extent 2m; 
 sql> alter tablespace app_data default storage(initial 2m next 2m maxextents 999); 
    <5>.taking tablespace offline or online 
 sql> alter tablespace app_data offline; 
 sql> alter tablespace app_data online; 
    <6>.read_only tablespace 
 sql> alter tablespace app_data read only|write; 
    <7>.droping tablespace 
 sql> drop tablespace app_data including contents; 
    <8>.enableing automatic extension of data files 
 sql> alter tablespace app_data add datafile 'c:/oracle/oradata/app_data01.dbf' size 200m 
 sql> autoextend on next 10m maxsize 500m; 
    <9>.change the size fo data files manually 
 sql> alter database datafile 'c:/oracle/oradata/app_data.dbf' resize 200m; 
   <10>.Moving data files: alter tablespace 
 sql> alter tablespace app_data rename datafile 'c:/oracle/oradata/app_data.dbf' 
 sql> to 'c:/oracle/app_data.dbf'; 
   <11>.moving data files:alter database 
 sql> alter database rename file 'c:/oracle/oradata/app_data.dbf' 
 sql> to 'c:/oracle/app_data.dbf'; 
78、BACKUP and RECOVERY 
<1>. v$sga,v$instance,v$process,v$bgprocess,v$database,v$datafile,v$sgastat 
<2>. Rman need set dbwr_IO_slaves or backup_tape_IO_slaves and large_pool_size 
<3>. Monitoring Parallel Rollback 
 v$fast_start_servers , v$fast_start_transactions 
<4>.perform a closed database backup (noarchivelog) 
 shutdown immediate 
 cp files /backup/ 
 startup 
<5>.restore to a different location 
connect system/manager as sysdba 
startup mount 
alter database rename file '/disk1/../user.dbf' to '/disk2/../user.dbf'; 
alter database open; 
<6>.recover syntax 
--recover a mounted database 
recover database; 
recover datafile '/disk1/data/df2.dbf'; 
alter database recover database; 
--recover an opened database 
recover tablespace user_data; 
recover datafile 2; 
alter database recover datafile 2; 
<7>.how to apply redo log files automatically 
set autorecovery on 
recover automatic datafile 4; 
<8>.complete recovery: 
--method 1(mounted databae) 
copy c:/backup/user.dbf c:/oradata/user.dbf 
startup mount 
recover datafile 'c:/oradata/user.dbf; 
alter database open; 
--method 2(opened database,initially opened,not system or rollback datafile) 
copy c:/backup/user.dbf c:/oradata/user.dbf (alter tablespace offline) 
recover datafile 'c:/oradata/user.dbf' or 
recover tablespace user_data; 
alter database datafile 'c:/oradata/user.dbf' online or 
alter tablespace user_data online; 
--method 3(opened database,initially closed not system or rollback datafile) 
startup mount 
alter database datafile 'c:/oradata/user.dbf' offline; 
alter database open 
copy c:/backup/user.dbf d:/oradata/user.dbf 
alter database rename file 'c:/oradata/user.dbf' to 'd:/oradata/user.dbf' 
recover datafile 'e:/oradata/user.dbf' or recover tablespace user_data; 
alter tablespace user_data online; 
--method 4(loss of data file with no backup and have all archive log) 
alter tablespace user_data offline immediate; 
alter database create datafile 'd:/oradata/user.dbf' as 'c:/oradata/user.dbf'' 
recover tablespace user_data; 
alter tablespace user_data online 
<9>.perform an open database backup 
alter tablespace user_data begin backup; 
copy files /backup/ 
alter database datafile '/c:/../data.dbf' end backup; 
alter system switch logfile; 
<10>.backup a control file 
alter database backup controlfile to 'control1.bkp'; 
alter database backup controlfile to trace; 
<11>.recovery (noarchivelog mode) 
shutdown abort 
cp files 
startup 
<12>.recovery of file in backup mode 
alter database datafile 2 end backup; 
<13>.clearing redo log file 
alter database clear
 
 
、通常oracle需要启动OracleServiceORCL,OracleStartORCL,OracleTNSListener 任务
    在NT上至少要启动两个服务
       oraclestartID和oracleserverID
每个数据库都有一个系统标识符(SID),典型安装的数据库使用的系统标识符是ORCL
原创粉丝点击