oracle筆記四

1、通常oracle需要啓動OracleServiceORCL,OracleStartORCL,OracleTNSListener 任務
    在NT上至少要啓動兩個服務
       oraclestartID和oracleserverID
每個數據庫都有一個系統標識符(SID),典型安裝的數據庫使用的系統標識符是ORCL

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=${ORACLE_BASE}/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=${ORACLE_BASE}/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=<sid>;
  Select * from v$sqltext where address=<sql_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 unarchived logfile group 1;
alter database clear unarchived logfile group 1 unrecoverable datafile;

<14>.redo log recovery
alter database add logfile group 3 'c:/oradata/redo03.log' size 1000k;
alter database drop logfile group 1;
alter database open;
or >cp c:/oradata/redo02.log' c:/oradata/redo01.log
alter database clear logfile 'c:/oradata/log01.log';

79 managing password security and resources

<1>.controlling account lock and password
sql> alter user juncky identified by oracle account unlock;

<2>.user_provided password function
sql> function_name(userid in varchar2(30),password in varchar2(30),
old_password in varchar2(30)) return boolean

<3>.create a profile : password setting
sql> create profile grace_5 limit failed_login_attempts 3
sql> password_lock_time unlimited password_life_time 30
sql>password_reuse_time 30 password_verify_function verify_function
sql> password_grace_time 5;

<4>.altering a profile
sql> alter profile default failed_login_attempts 3
sql> password_life_time 60 password_grace_time 10;

<5>.drop a profile
sql> drop profile grace_5 [cascade];

<6>.create a profile : resource limit
sql> create profile developer_prof limit sessions_per_user 2
sql> cpu_per_session 10000 idle_time 60 connect_time 480;

<7>. view => resource_cost : alter resource cost
dba_Users,dba_profiles

<8>. enable resource limits
sql> alter system set resource_limit=true;


80.managing privileges

<1>.system privileges: view => system_privilege_map ,dba_sys_privs,session_privs

<2>.grant system privilege
sql> grant create session,create table to managers;
sql> grant create session to scott with admin option;
with admin option can grant or revoke privilege from any user or role;

<3>.sysdba and sysoper privileges:
sysoper: startup,shutdown,alter database open|mount,alter database backup controlfile,
alter tablespace begin/end backup,recover database
alter database archivelog,restricted session
sysdba: sysoper privileges with admin option,create database,recover database until

<4>.password file members: view:=> v$pwfile_users

<5>.O7_dictionary_accessibility =true restriction access to view or tables in other schema

<6>.revoke system privilege
sql> revoke create table from karen;
sql> revoke create session from scott;

<7>.grant object privilege
sql> grant execute on dbms_pipe to public;
sql> grant update(first_name,salary) on employee to karen with grant option;

<8>.display object privilege : view => dba_tab_privs, dba_col_privs

<9>.revoke object privilege
sql> revoke execute on dbms_pipe from scott [cascade constraints];

<10>.audit record view :=> sys.aud$

<11>. protecting the audit trail
sql> audit delete on sys.aud$ by access;

<12>.statement auditing
sql> audit user;

<13>.privilege auditing
sql> audit select any table by summit by access;

<14>.schema object auditing
sql> audit lock on summit.employee by access whenever successful;

<15>.view audit option : view=> all_def_audit_opts,dba_stmt_audit_opts,dba_priv_audit_opts,dba_obj_audit_opts

<16>.view audit result: view=> dba_audit_trail,dba_audit_exists,dba_audit_object,dba_audit_session,dba_audit_statement

81 manager role

<1>.create roles
sql> create role sales_clerk;
sql> create role hr_clerk identified by bonus;
sql> create role hr_manager identified externally;

<2>.modify role
sql> alter role sales_clerk identified by commission;
sql> alter role hr_clerk identified externally;
sql> alter role hr_manager not identified;

<3>.assigning roles
sql> grant sales_clerk to scott;
sql> grant hr_clerk to hr_manager;
sql> grant hr_manager to scott with admin option;

<4>.establish default role
sql> alter user scott default role hr_clerk,sales_clerk;
sql> alter user scott default role all;
sql> alter user scott default role all except hr_clerk;
sql> alter user scott default role none;

<5>.enable and disable roles
sql> set role hr_clerk;
sql> set role sales_clerk identified by commission;
sql> set role all except sales_clerk;
sql> set role none;

<6>.remove role from user
sql> revoke sales_clerk from scott;
sql> revoke hr_manager from public;

<7>.remove role
sql> drop role hr_manager;

<8>.display role information
view: =>dba_roles,dba_role_privs,role_role_privs,dba_sys_privs,role_sys_privs,role_tab_privs,session_roles


81.查詢當前正在執行的job的情況
   有時候對於需要執行的job查詢執行情況,比如正在執行那條語句,或者想把job停下來等。一般不知道怎麼查詢到
   job執行的session的sid.
   方法一:
    select * from dba_jobs_running
    如果運行比較慢,加
    select /*+ rule */* from dba_jobs_running
   方法二:
   <1>首先得到job號,從user_jobs或者dba_jobs
    select * from user_jobs where upper(what) like '%MYPROGRAM%'
   <2> 根據job號查詢sid號
    select * from v$lock where id2 = 3361910 and type ='JQ'
        就可以查詢到sid了
   比如查詢當前的執行什麼語句
    select sql_text from v$sqlarea a,v$lock b,v$session c,user_jobs d
    where d.upper(what) like '%2004PRESENT%'
    and d.job = b.id2
    and b.type='JQ'
    and b.sid = c.sid
    and a.hash_value = c.sql_hash_value
    and a.address = c.sql_address

82.怎麼樣給sqlplus安裝幫助
[A]SQLPLUS的幫助必須手工安裝,shell腳本爲$ORACLE_HOME/bin/helpins
在安裝之前,必須先設置SYSTEM_PASS環境變量,如:
$ setenv SYSTEM_PASS SYSTEM/MANAGER
$ helpins
如果不設置該環境變量,將在運行腳本的時候提示輸入環境變量
當然,除了shell腳本,還可以利用sql腳本安裝,那就不用設置環境變量了,但是,我們必須以system登錄。
$ sqlplus system/manager
SQL> @?/sqlplus/admin/help/helpbld.sql helpus.sql
安裝之後,你就可以象如下的方法使用幫助了
SQL> help index

83.如何移動數據文件
<1>、關閉數據庫,利用os拷貝
a.shutdown immediate關閉數據庫
b.在os下拷貝數據文件到新的地點
c.Startup mount 啓動到mount下
d.Alter database rename datafile '老文件' to '新文件';
e.Alter database open; 打開數據庫
<2>、利用Rman聯機操作
RMAN> sql "alter database datafile ''file name'' offline";
RMAN> run {
2> copy datafile 'old file location'
3> to 'new file location';
4> switch datafile ' old file location'
5> to datafilecopy ' new file location';
6> }
RMAN> sql "alter database datafile ''file name'' online";
說明:利用OS拷貝也可以聯機操作,不關閉數據庫,與rman的步驟一樣,利用rman與利用os拷貝的原理一樣,在rman中copy是拷貝數據文件,相當於OS的cp,而switch則相當於alter database rename,用來更新控制文件。

84.如何管理聯機日誌組與成員
以下是常見操作,如果在OPA/RAC下注意線程號
增加一個日誌文件組
Alter database add logfile [group n] '文件全名' size 10M;
在這個組上增加一個成員
Alter database add logfile member '文件全名' to group n;
在這個組上刪除一個日誌成員
Alter database drop logfile member '文件全名';
刪除整個日誌組
Alter database drop logfile group n;

85.怎麼樣計算REDO BLOCK的大小
[A]計算方法爲(redo size + redo wastage) / redo blocks written + 16
具體見如下例子
SQL> select name ,value from v$sysstat where name like '%redo%';
NAME VALUE
---------------------------------------------------------------- ----------
redo synch writes 2
redo synch time 0
redo entries 76
redo size 19412
redo buffer allocation retries 0
redo wastage 5884
redo writer latching time 0
redo writes 22
redo blocks written 51
redo write time 0
redo log space requests 0
redo log space wait time 0
redo log switch interrupts 0
redo ordering marks 0
SQL> select (19412+5884)/51 + 16 '"Redo black(byte)" from dual;
Redo black(byte)
------------------
512

86.如果發現表中有壞塊,如何檢索其它未壞的數據
[A]首先需要找到壞塊的ID(可以運行dbverify實現),假設爲,假定文件編碼爲。運行下面的查詢查找段名:
SELECT segment_name,segment_type,extent_id,block_id, blocks
from dba_extents t
where
file_id =
AND between block_id and (block_id + blocks - 1)
一旦找到壞段名稱,若段是一個表,則最好建立一個臨時表,存放好的數據。若段是索引,則刪除它,再重建。
create table good_table
as
select from bad_table where rowid not in
(select rowid
from bad_table where substr(rowid,10,6) = )
在這裏要注意8以前的受限ROWID與現在ROWID的差別。
還可以使用診斷事件10231
SQL> ALTER SYSTEM SET EVENTS '10231 trace name context forever,level 10';
創建一個臨時表good_table的表中除壞塊的數據都檢索出來
SQL>CREATE TABLE good_table as select * from bad_table;
最後關閉診斷事件
SQL> ALTER SYSTEM SET EVENTS '10231 trace name context off ';
關於ROWID的結構,還可以參考dbms_rowid.rowid_create函數

87.怎麼樣備份控制文件
在線備份爲一個二進制的文件
alter database backup controlfile to '$BACKUP_DEPT/controlfile.000' [reuse];
備份爲文本文件方式
alter database backup controlfile to trace [resetlogs|noresetlogs];

88.控制文件損壞如何恢復
<1>、如果是損壞單個控制文件
只需要關閉數據庫,拷貝一個好的數據文件覆蓋掉壞的數據文件即可
或者是修改init.ora文件的相關部分
<2>、如果是損失全部控制文件,則需要創建控制文件或從備份恢復
創建控制文件的腳本可以通過alter database backup controlfile to trace獲取。

89.怎麼樣熱備份一個表空間
<1>Alter tablespace 名稱 begin backup;
host cp 這個表空間的數據文件 目的地;
Alter tablespace 名稱 end backup;
如果是備份多個表空間或整個數據庫,只需要一個一個表空間的操作下來就可以了。

90.怎麼快速得到整個數據庫的熱備腳本
<1>可以寫一段類似的腳本
SQL>set serveroutput on
begin
dbms_output.enable(10000);
for bk_ts in (select distinct t.ts#,t.name from v$tablespace t,v$datafile d where t.ts#=d.ts#) loop
dbms_output.put_line('--'||bk_ts.name);
dbms_output.put_line('alter tablespace '||bk_ts.name||' begin backup;');
for bk_file in (select file#,name from v$datafile where ts#=bk_ts.ts#) loop
dbms_output.put_line('host cp '||bk_file.name||' $BACKUP_DEPT/');
end loop;
dbms_output.put_line('alter tablespace '||bk_ts.name||' end backup;');
end loop;
end;
/

91.丟失一個數據文件,但是沒有備份,怎麼樣打開數據庫
如果沒有備份只能是刪除這個數據文件了,會導致相應的數據丟失。
SQL>startup mount
--ARCHIVELOG模式命令
SQL>Alter database datafile 'file name' offline;
--NOARCHIVELOG模式命令
SQL>Alter database datafile 'file name' offline drop;
SQLl>Alter database open;
注意:該數據文件不能是系統數據文件

92.丟失一個數據文件,沒有備份但是有該數據文件創建以來的歸檔怎麼恢復
保證如下條件
a. 不能是系統數據文件
b. 不能丟失控制文件
如果滿足以上條件,則
SQL>startup mount
SQL>Alter database create datafile 'file name' as 'file name' size ... reuse;
SQL>recover datafile n; -文件號
或者
SQL>recover datafile 'file name';
或者
SQL>recover database;
SQL>Alter database open;

93.聯機日誌損壞如何恢復
<1>、如果是非當前日誌而且歸檔,可以使用
Alter database clear logfile group n來創建一個新的日誌文件
如果該日誌還沒有歸檔,則需要用
Alter database clear unarchived logfile group n
<2>、如果是當前日誌損壞,一般不能clear,則可能意味着丟失數據
如果有備份,可以採用備份進行不完全恢復
如果沒有備份,可能只能用_allow_resetlogs_corruption=true來進行強制恢復了,但是,這樣的方法是不建議的,最好在有Oracle support的指導下進行。

94.怎麼樣創建RMAN恢復目錄
首先,創建一個數據庫用戶,一般都是RMAN,並給予recovery_catalog_owner角色權限
sqlplus sys
SQL> create user rman identified by rman;
SQL> alter user rman default tablespace tools temporary tablespace temp;
SQL> alter user rman quota unlimited on tools;
SQL> grant connect, resource, recovery_catalog_owner to rman;
SQL> exit;
然後,用這個用戶登錄,創建恢復目錄
rman catalog rman/rman
RMAN> create catalog tablespace tools;
RMAN> exit;
最後,你可以在恢復目錄註冊目標數據庫了
rman catalog rman/rman target backdba/backdba
RMAN> register database;

95.怎麼樣在恢復的時候移動數據文件,恢復到別的地點
給一個RMAN的例子
run {
set until time 'Jul 01 1999 00:05:00';
allocate channel d1 type disk;
set newname for datafile '/u04/oracle/prod/sys1prod.dbf'
to '/u02/oracle/prod/sys1prod.dbf';
set newname for datafile '/u04/oracle/prod/usr1prod.dbf'
to '/u02/oracle/prod/usr1prod.dbf';
set newname for datafile '/u04/oracle/prod/tmp1prod.dbf'
to '/u02/oracle/prod/tmp1prod.dbf';
restore controlfile to '/u02/oracle/prod/ctl1prod.ora';
replicate controlfile from '/u02/oracle/prod/ctl1prod.ora';
restore database;
sql "alter database mount";
switch datafile all;
recover database;
sql "alter database open resetlogs";
release channel d1;
}
96.怎麼從備份片(backuppiece)中恢復(restore)控制文件與數據文件
可以使用如下方法,在RMAN中恢復備份片的控制文件
restore controlfile from backuppiecefile;
如果是9i的自動備份,可以採用如下的方法
restore controlfile from autobackup;
但是,如果控制文件全部丟失,需要指定DBID,如SET DBID=?
自動備份控制文件的默認格式是%F,這個格式的形式爲
c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII就是DBID
至於恢復(restore)數據文件,oracle 816開始有個包dbms_backup_restore
在 nomount 狀態下就可以執行,可以讀 815甚至之前的備份片,讀出來的文件用於恢復
可以在SQLPLUS中運行,如下
SQL>startup nomount
SQL> DECLARE
2 devtype varchar2(256);
3 done boolean;
4 BEGIN
5 devtype := dbms_backup_restore.deviceallocate('', params=>'');
6 dbms_backup_restore.restoresetdatafile;
7 dbms_backup_restore.restorecontrolfileto('E:/Oracle/oradata/penny/control01.ctl');
8 dbms_backup_restore.restoreDataFileto(1,'E:/Oracle/oradata/penny/system01.dbf');
9 dbms_backup_restore.restoreDataFileto(2,'E:/Oracle/oradata/penny/UNDOTBS01.DBF');
10 dbms_backup_restore.restoreDataFileto(3,'E:/ORACLE/ORADATA/PENNY/USERS01.DBF');
11 dbms_backup_restore.restorebackuppiece('D:/orabak/BACKUP_1_4_04F4IAJT.PENNY',done=>done);
12 END;
13 /
PL/SQL 過程已成功完成。
SQL> alter database mount;
[Q]Rman的format格式中的%s類似的東西代表什麼意義
[A]可以參考如下
%c 備份片的拷貝數
%d 數據庫名稱
%D 位於該月中的第幾天 (DD)
%M 位於該年中的第幾月 (MM)
%F 一個基於DBID唯一的名稱,這個格式的形式爲c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII爲該數據庫的DBID,YYYYMMDD爲日期,QQ是一個1-256的序列
%n 數據庫名稱,向右填補到最大八個字符
%u 一個八個字符的名稱代表備份集與創建時間
%p 該備份集中的備份片號,從1開始到創建的文件數
%U 一個唯一的文件名,代表%u_%p_%c
%s 備份集的號
%t 備份集時間戳
%T 年月日格式(YYYYMMDD)

97.執行exec dbms_logmnr_d.build('Logminer.ora','file directory'),提示下標超界,怎麼辦
完整錯誤信息如下,
SQL> exec dbms_logmnr_d.build('Logminer.ora','file directory')
BEGIN dbms_logmnr_d.build('Logminer.ora','file directory'); END;
*
ERROR 位於第 1 行:
ORA-06532: 下標超出限制
ORA-06512: 在"SYS.DBMS_LOGMNR_D", line 793
ORA-06512: 在line 1
解決辦法爲:
<1>.編輯位於"$ORACLE_HOME/rdbms/admin"目錄下的文件"dbmslmd.sql"
改變行:
TYPE col_desc_array IS VARRAY(513) OF col_description;

TYPE col_desc_array IS VARRAY(700) OF col_description;
並保存文件
<2>. 運行改變後的腳本
SQLPLUS> Connect internal
SQLPLUS> @$ORACLE_HOME/rdbms/admin/dbmslmd.sql
<3>.重新編譯該包
SQLPLUS> alter package DBMS_LOGMNR_D compile body;

98.執行execute dbms_logmnr.start_logmnr(DictFileName=>'DictFileName')提示ORA-01843:無效的月份,這個是什麼原因
我們分析start_logmnr包
PROCEDURE start_logmnr(
startScn IN NUMBER default 0 ,
endScn IN NUMBER default 0,
startTime IN DATE default TO_DATE('01-jan-1988','DD-MON-YYYY'),
endTime IN DATE default TO_DATE('01-jan-2988','DD-MON-YYYY'),
DictFileName IN VARCHAR2 default '',
Options IN BINARY_INTEGER default 0 );
可以知道,如果TO_DATE('01-jan-1988','DD-MON-YYYY')失敗,將導致以上錯誤
所以解決辦法可以爲
<1>、Alter session set NLS_LANGUAGE=American
<2>、用類似如下的方法執行
execute dbms_logmnr.start_logmnr (DictFileName=> 'f:/temp2/TESTDICT.ora', starttime => TO_DATE(
'01-01-1988','DD-MM-YYYY'), endTime=>TO_DATE('01-01-2988','DD-MM-YYYY'));


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章