文章詳情頁(yè)
我的oracle筆記四(DBA管理)
瀏覽:117日期:2023-11-27 08:25:05
1、通常Oracle需要啟動(dòng)OracleServiceORCL,OracleStartORCL,OracleTNSListener 任務(wù) 在NT上至少要啟動(dòng)兩個(gè)服務(wù) oraclestartID和oracleserverID每個(gè)數(shù)據(jù)庫(kù)都有一個(gè)系統(tǒng)標(biāo)識(shí)符(SID),典型安裝的數(shù)據(jù)庫(kù)使用的系統(tǒng)標(biāo)識(shí)符是ORCL2、啟動(dòng)關(guān)閉數(shù)據(jù)庫(kù) 關(guān)閉: svrmgr>connect internal/oracle >shutdown--正常關(guān)閉數(shù)據(jù)庫(kù) svrmgr>shutdown; immediate; --立即關(guān)閉數(shù)據(jù)庫(kù) svrmgr>shutdown abort; --一種最直接的關(guān)閉數(shù)據(jù)庫(kù)的方式,執(zhí)行之后,重新啟動(dòng)需要花6-8小時(shí) 啟動(dòng): svrmgr>startup; --正常啟動(dòng) --等價(jià)于:startup nomount; alter database; mount; alter database; open; svrmgr>startup mount; --安裝啟動(dòng):用于改變數(shù)據(jù)庫(kù)的歸檔或執(zhí)行恢復(fù)狀態(tài) svrmgr>startup nomount--用于重建控制文件或重建數(shù)據(jù)庫(kù) svrmgr>startup; restrict; --約束啟動(dòng),能啟動(dòng)數(shù)據(jù)庫(kù),但只答應(yīng)具有一定特權(quán)的用戶(hù)訪問(wèn) 假如希望改變這種狀態(tài),連接成功后 alter system disable restricted session; svrmgr>startup force;當(dāng)不能關(guān)閉數(shù)據(jù)庫(kù)時(shí),可采用強(qiáng)制啟動(dòng)數(shù)據(jù)庫(kù)來(lái)完成數(shù)據(jù)庫(kù)的關(guān)閉操作。 svrmgr>startup pfile=d:orantdatabaseinitorcl.ora; --帶初始化參數(shù)文件的啟動(dòng)3、缺省用戶(hù)和密碼<1>. Oracle安裝完成后的初始口令? internal/oracle sys/change_on_install system/manager scott/tiger sysman/oem_temp<2>. ORACLE9IAS WEB CACHE的初始默認(rèn)用戶(hù)和密碼? administrator/administrator4、讓定義自己的回滾段生效 在initorcl.ora中加入rollback_segments=(rb0,rb1,...) 其中rb0,rb1為自己定義的回滾段,可使這些回滾段在啟動(dòng)時(shí)生效5、查看修改數(shù)據(jù)庫(kù)的字符集<1>數(shù)據(jù)庫(kù)服務(wù)器字符集; 在表props$中 update props$ set value$='ZHS16CGB231280' where name ='NLS_CHARACTERSET' 然后重新啟動(dòng)數(shù)據(jù)庫(kù),而不需要重新安裝8i以上版本可以通過(guò)alter database來(lái)修改字符集,但也只限于子集到超集,不建議修改props$表,將可能導(dǎo)致嚴(yán)重錯(cuò)誤。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查看數(shù)據(jù)庫(kù)字符集:SELECT *; FROM NLS_DATABASE_PARAMETERS; SELECT *; FROM V$NLS_PARAMETERS;<2>客戶(hù)端字符集環(huán)境select * from nls_instance_parameters,其來(lái)源于v$parameter,表示客戶(hù)端的字符集的設(shè)置,可能是參數(shù)文件,環(huán)境變量或者是注冊(cè)表 會(huì)話字符集環(huán)境 select * from nls_session_parameters,其來(lái)源于v$nls_parameters,表示會(huì)話自己的設(shè)置,可能是會(huì)話的環(huán)境變量或者是alter session完成,假如會(huì)話沒(méi)有非凡的設(shè)置,將與nls_instance_parameters一致。客戶(hù)端的字符集要求與服務(wù)器一致,才能正確顯示數(shù)據(jù)庫(kù)的非Ascii字符。假如多個(gè)設(shè)置存在的時(shí)候,alter session>環(huán)境變量>注冊(cè)表>參數(shù)文件字符集要求一致,但是語(yǔ)言設(shè)置卻可以不同,語(yǔ)言設(shè)置建議用英文。如字符集是zhs16gbk,則nls_lang可以是American_America.zhs16gbk。<3> 有時(shí)候用crontab發(fā)起的時(shí)候,由于執(zhí)行的shell腳本的不同,導(dǎo)致很多的環(huán)境變量不同。經(jīng)常看到插入到數(shù)據(jù)庫(kù)中的漢字變成亂碼。 比如shell腳本cai.sh如下內(nèi)容。#!/bin/ksheXPort ORACLE_BASE=/u01/oracle/app/oracleexport ORACLE_HOME=${ORACLE_BASE}/prodUCt/9.2.0export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/dataexport LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATHexport 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是個(gè)大好人呀');commit;quit!在crontab中定時(shí)天天20:19執(zhí)行一次19 20 * * * /bin/sh /app/prepay/cai.sh >/dev/null 2>&1 &則可以看到數(shù)據(jù)庫(kù)中數(shù)據(jù)變成了:2LQSJY當(dāng)前數(shù)據(jù)庫(kù)的字符集是SELECT *; FROM NLS_DATABASE_PARAMETERSAMERICAN.ZHS16GBK為了正常,必須保持客戶(hù)端和數(shù)據(jù)庫(kù)一致的字符集改腳本如下即可#!/bin/kshexport ORACLE_BASE=/u01/oracle/app/oracleexport ORACLE_HOME=${ORACLE_BASE}/product/9.2.0export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/dataexport LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATHexport 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是個(gè)大好人呀');commit;quit!6、svgmgr>show sga7、查詢(xún)鎖的原因 假如進(jìn)程被死鎖,可以按下面方式查詢(xún)<1> 從v$session或者v$locked_object找到此session<2> 假如有l(wèi)ockwait,查詢(xún)v$lock, select * from v$lock where kaddr = 'C00000024AB87210' 假如沒(méi)有,根據(jù)sid select * from v$lock where sid = 438<3> 查看v$lock lmode > 0,表示已經(jīng)得到此鎖 request > 0 表示正在請(qǐng)求此鎖 根據(jù)id1和id2的值可以判定請(qǐng)求哪個(gè)鎖的釋放。 select * from v$lock where id1=134132 and id2 = 31431 8. 查詢(xún)鎖的狀況的對(duì)象V$LOCK,; V$LOCKED_OBJECT,; V$SESSION,; V$SQLAREA,; V$PROCESS ; 查詢(xún)鎖的表的方法: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. 怎樣查得數(shù)據(jù)庫(kù)的SID ?select name from v$database; 也可以直接查看 init.ora文件10、治理回滾段: 存放事務(wù)的恢復(fù)信息 建立回滾段 create public; rollback segment SEG_NAME; tabelspace TABLESPACE_NAME; alterrollback segment SEG_NAME; online; 刪除回滾段 首先改變?yōu)閛ffline狀態(tài) 直接使用回滾段 sql>set transaction; use; rollback; segment; SEG_NAME;11. 計(jì)算一個(gè)表占用的空間的大小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 check12. 表在表空間中的存儲(chǔ)情況 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. 索引在表空間中的存儲(chǔ)情況 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、程序中報(bào)錯(cuò):maxinum cursor exceed! <1> 查看當(dāng)前的open cursor參數(shù) sql> show parameter open_cursors <2> 假如確實(shí)很小,應(yīng)該調(diào)整數(shù)據(jù)庫(kù)初始化文件 加如一項(xiàng); open_cursors=200 <3> 假如很大,則select sid,sql_text,count(*) from v$open_cursorgroup by sid,sql_texthaving count(*) > 200 其中200是隨便寫(xiě)一個(gè)比較大的值。查詢(xún)得到打開(kāi)太多的cursor.17、查看數(shù)據(jù)庫(kù)的版本信息SQL> select; * from v$version;包含版本信息,核心版本信息,位數(shù)信息(32位或64位)等至于位數(shù)信息,在Linux/unix平臺(tái)上,可以通過(guò)file查看,如file $ORACLE_HOME/bin/oracle18. 查看最大會(huì)話數(shù)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個(gè)用戶(hù)。 ;select * from v$license; 其中sessions_highwater紀(jì)錄曾經(jīng)到達(dá)的最大會(huì)話數(shù) 19. 以archivelog的方式運(yùn)行oracle。 init.ora log_archive_start = true RESTART DATABASE20. unix 下調(diào)整數(shù)據(jù)庫(kù)的時(shí)間su -root date -u 0801000021.P4電腦的安裝方法 將SYMCJIT.DLL改為SYSMCJIT.OLD22. 如何查詢(xún)SERVER是不是OPS? SELECT *; FROM V$OPTION; 假如PARALLEL SERVER=TRUE則有OPS能23. 查詢(xún)每個(gè)用戶(hù)的權(quán)限SELECT *; FROM DBA_SYS_PRIVS;24.將表/索引移動(dòng)表空間ALTER TABLE TABLE_NAME MOVE TABLESPACE_NAME;ALTER INDEX INDEX_NAME REBUILD TABLESPACE TABLESPACE_NAME;25.在LINUX,UNIX下啟動(dòng)DBA STUDIO?OEMAPP; DBASTUDIO26.LINUX下查詢(xún)磁盤(pán)競(jìng)爭(zhēng)狀況命令? Sar; -d27.LINUX下查詢(xún)磁盤(pán)CPU競(jìng)爭(zhēng)狀況命令? sar-r28. 查詢(xún)表空間信息? SELECT *; FROM; DBA_DATA_FILES;29. 看各個(gè)表空間占用磁盤(pán)情況:SQL> col tablespace format a20 SQL> select b.file_id; 文件ID號(hào), b.tablespace_name;;表空間名, b.bytes字節(jié)數(shù), (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_id30. 如把ORACLE設(shè)置為MTS或?qū)S媚J剑?#dispatchers='(PROTOCOL=TCP) (SERVICE=SIDXDB)' 加上就是MTS,注釋就是專(zhuān)用模式,SID是指你的實(shí)例名。 31. 如何才能得知系統(tǒng)當(dāng)前的SCN號(hào) ?select max(ktuxescnw * power(2, 32) + ktuxescnb) from x$ktuxe;32. 修改oracel數(shù)據(jù)庫(kù)的默認(rèn)日期alter session set nls_date_format='yyyymmddhh24miss'; OR 可以在init.ora中加上一行 nls_date_format='yyyymmddhh24miss' 33. 將小表放入keep池中alter table xxx storage(buffer_pool keep); 34. 如何檢查是否安裝了某個(gè)patch? check that; oraInventory 35. 如何修改oracle數(shù)據(jù)庫(kù)的用戶(hù)連接數(shù)? 修改initSID.ora,將process加大,重啟數(shù)據(jù)庫(kù). 36. 如何創(chuàng)建SPFILE?SQL> connect / as sysdba SQL> select * from v$version; SQL> create pfile from spfile; SQL> CREATE SPFILE FROM PFILE='E:ora9iadmineyglepfileinit.ora'; 文件已創(chuàng)建。 SQL> CREATE SPFILE='E:ora9idatabaseSPFILEEYGLE.ORA' FROM PFILE='E:ora9iadmineyglepfileinit.ora'; 文件已創(chuàng)建。 37. 內(nèi)核參數(shù)的應(yīng)用 shmmax含義:這個(gè)設(shè)置并不決定究竟Oracle數(shù)據(jù)庫(kù)或者操作系統(tǒng)使用多少物理內(nèi)存,只決定了最多可以使用的內(nèi)存數(shù)目。這個(gè)設(shè)置也不影響操作系統(tǒng)的內(nèi)核資源。 設(shè)置方法:0.5*物理內(nèi)存 例子:Set shmsys:shminfo_shmmax=10485760 shmmin 含義:共享內(nèi)存的最小大小。 設(shè)置方法:一般都設(shè)置成為1。 例子:Set shmsys:shminfo_shmmin=1: shmmni 含義:系統(tǒng)中共享內(nèi)存段的最大個(gè)數(shù)。 例子:Set shmsys:shminfo_shmmni=100 shmseg 含義:每個(gè)用戶(hù)進(jìn)程可以使用的最多的共享內(nèi)存段的數(shù)目。 例子:Set shmsys:shminfo_shmseg=20: semmni 含義:系統(tǒng)中semaphore identifierer的最大個(gè)數(shù)。 設(shè)置方法:把這個(gè)變量的值設(shè)置為這個(gè)系統(tǒng)上的所有Oracle的實(shí)例的init.ora中的最大的那個(gè)processes的那個(gè)值加10。 例子:Set semsys:seminfo_semmni=100 semmns 含義:系統(tǒng)中emaphores的最大個(gè)數(shù)。 設(shè)置方法:這個(gè)值可以通過(guò)以下方式計(jì)算得到:各個(gè)Oracle實(shí)例的initSID.ora里邊的processes的值的總和(除去最大的Processes參數(shù))+最大的那個(gè)Processes×2+10×Oracle實(shí)例的個(gè)數(shù)。 例子:Set semsys:seminfo_semmns=200 semmsl: 含義:一個(gè)set中semaphore的最大個(gè)數(shù)。 設(shè)置方法:設(shè)置成為10+所有Oracle實(shí)例的InitSID.ora中最大的Processes的值。 例子:Set semsys:seminfo_semmsl=-20038. 怎樣查看哪些用戶(hù)擁有SYSDBA、SYSOPER權(quán)限? SQL>conn sys/change_on_installSQL>select * from V_$PWFILE_USERS; 39. 如何查看數(shù)據(jù)文件放置的路徑 ? col file_name format a50SQL> select tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_files order by file_id; 40. 如何查看現(xiàn)有回滾段及其狀態(tài) ? SQL> col segment format a30SQL> SELECT SEGMENT_NAME,OWNER,TABLESPACE_NAME,SEGMENT_ID,FILE_ID,STATUS FROM DBA_ROLLBACK_SEGS 41. Oracle常用系統(tǒng)文件有哪些? 通過(guò)以下視圖顯示這些文件信息:v$database,v$datafile,v$logfile v$controlfile v$parameter; 42.查看數(shù)據(jù)庫(kù)實(shí)例SQL>SELECT * FROM V$INSTANCE; 43. 怎樣估算SQL執(zhí)行的I/O數(shù) ? SQL>SET AUTOTRACE ON ; SQL>SELECT * FROM TABLE; OR SQL>SELECT *; FROM; v$filestat ; 可以查看IO數(shù) 44. 怎樣擴(kuò)大REDO LOG的大小? 建立一個(gè)臨時(shí)的redolog組,然后切換日志,刪除以前的日志,建立新的日志。 45. 查詢(xún)做比較大的排序的進(jìn)程? <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>. 查詢(xún)做比較大的排序的進(jìn)程的SQL語(yǔ)句 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的值,增加區(qū)的大小,設(shè)置一個(gè)高的OPTIMAL值。 假如是執(zhí)行大的事務(wù),報(bào)此錯(cuò)誤,說(shuō)明oracle給此事務(wù)隨機(jī)分配的回滾段太小了,這時(shí)可以為它指定一個(gè)足夠大的回滾段,以確保這個(gè)事務(wù)的成功執(zhí)行.例如 set transaction use rollback segment roll_abc; delete from table_name where ... commit; 回滾段roll_abc被指定給這個(gè)delete事務(wù),commit命令則在事務(wù)結(jié)束之后取消了回滾段的指定. 47. 事務(wù)要求的回滾段空間不夠,表現(xiàn)為表空間用滿(mǎn)(ORA-01560錯(cuò)誤),回滾段擴(kuò)展到達(dá)參數(shù);;;MAXEXTENTS的值(ORA-01628)的解決辦法. 向回滾段表空間添加文件或使已有的文件變大;增加MAXEXTENTS的值。 ;48. 監(jiān)控事例的等待 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. 回滾段的爭(zhēng)用情況 select name, waits, gets, waits/gets 'Ratio' from v$rollstat C, v$rollname D where C.usn = D.usn; 50 監(jiān)控表空間的 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、監(jiān)控文件系統(tǒng)的 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、監(jiān)控 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、監(jiān)控 SGA 中字典緩沖區(qū)的命中率 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、監(jiān)控 SGA 中共享緩存區(qū)的命中率,應(yīng)該小于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、顯示所有數(shù)據(jù)庫(kù)對(duì)象的類(lèi)別和大小 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、監(jiān)控 SGA 中重做日志緩存區(qū)的命中率,應(yīng)該小于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、監(jiān)控內(nèi)存和硬盤(pán)的排序比率,最好使它小于 .10,增加 sort_area_size SELECT name, value FROM v$sysstat WHERE name IN ('sorts (memory)', 'sorts;;;(disk)'); 58、監(jiān)控當(dāng)前數(shù)據(jù)庫(kù)誰(shuí)在運(yùn)行什么SQL語(yǔ)句? SELECT osuser, username, sql_text from v$session a, v$sqltext b where a.sql_address =b.address order by address, piece; 59、監(jiān)控字典緩沖區(qū)? 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、監(jiān)控 MTS select busy/(busy+idle) 'shared servers busy' from v$dispatcher; 此值大于0.5時(shí),參數(shù)需加大 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時(shí),參數(shù)需加大 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多的用戶(hù)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.如何檢查操作系統(tǒng)是否存在IO的問(wèn)題使用的工具有sar,這是一個(gè)比較通用的工具。#sar -u 2 10即每隔2秒檢察一次,共執(zhí)行20次,當(dāng)然這些都由你決定了。 ;;示例返回: ;;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指的是用戶(hù)進(jìn)程使用的cpu資源的百分比,%sys指的是系統(tǒng)資源使用cpu資源的百分比,%wio指的是等待io完成的百分比,這是值得我們觀注的一項(xiàng),%idle即空閑的百分比。假如wio列的值很大,如在35%以上,說(shuō)明你的系統(tǒng)的IO存在瓶頸,你的CPU花費(fèi)了很大的時(shí)間去等待IO的完成。Idle很小說(shuō)明系統(tǒng)CPU很忙。像我的這個(gè)示例,可以看到wio平均值為11說(shuō)明io沒(méi)什么非凡的問(wèn)題,而我的idle值為零,說(shuō)明我的cpu已經(jīng)滿(mǎn)負(fù)荷運(yùn)行了。64.關(guān)注一下內(nèi)存。常用的工具便是vmstat,對(duì)于hp-unix來(lái)說(shuō)可以用glance,Aix來(lái)說(shuō)可以用topas,當(dāng)你發(fā)現(xiàn)vmstat中pi列非零,memory中的free列的值很小,glance,topas中內(nèi)存的利用率多于80%時(shí),這時(shí)說(shuō)明你的內(nèi)存方面應(yīng)該調(diào)節(jié)一下了,方法大體有以下幾項(xiàng)。 a.劃給Oracle使用的內(nèi)存不要超過(guò)系統(tǒng)內(nèi)存的1/2,一般保在系統(tǒng)內(nèi)存的40%為益。 b.為系統(tǒng)增加內(nèi)存 c.假如你的連接非凡多,可以使用MTS的方式 d.打全補(bǔ)丁,防止內(nèi)存漏洞。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較大的正在運(yùn)行的sessionSELECT 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 prWHERE 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對(duì)檢索出的結(jié)果的幾點(diǎn)說(shuō)明:<1> 我是按每個(gè)正在等待的session已經(jīng)發(fā)生的物理讀排的序,因?yàn)樗c實(shí)際的IO相關(guān)。<2> 你可以看一下這些等待的進(jìn)程都在忙什么,語(yǔ)句是否合理? Select sql_address from v$session where sid=<sid>; Select * from v$sqltext where address=<sql_address>;執(zhí)行以上兩個(gè)語(yǔ)句便可以得到這個(gè)session的語(yǔ)句。你也以用alter system kill session 'sid,serial#';把這個(gè)session殺掉。<3> 應(yīng)觀注一下event這列,這是我們調(diào)優(yōu)的要害一列,下面對(duì)常出現(xiàn)的event做以簡(jiǎn)要的說(shuō)明: a、buffer busy waits,free buffer waits這兩個(gè)參數(shù)所標(biāo)識(shí)是dbwr是否夠用的問(wèn)題,與IO很大相關(guān)的,當(dāng)v$session_wait中的free buffer wait的條目很小或沒(méi)有的時(shí)侯,說(shuō)明你的系統(tǒng)的dbwr進(jìn)程決對(duì)夠用,不用調(diào)整;free buffer wait的條目很多,你的系統(tǒng)感覺(jué)起來(lái)一定很慢,這時(shí)說(shuō)明你的dbwr已經(jīng)不夠用了,它產(chǎn)生的wio已經(jīng)成為你的數(shù)據(jù)庫(kù)性能的瓶頸,這時(shí)的解決辦法如下:a.1增加寫(xiě)進(jìn)程,同時(shí)要調(diào)整db_block_lru_latches參數(shù) 示例:修改或添加如下兩個(gè)參數(shù) db_writer_processes=4 db_block_lru_latches=8a.2開(kāi)異步IO,IBM這方面簡(jiǎn)單得多,hp則麻煩一些,可以與Hp工程師聯(lián)系。 b、db file sequential read,指的是順序讀,即全表掃描,這也是我們應(yīng)該盡量減少的部分,解決方法就是使用索引、sql調(diào)優(yōu),同時(shí)可以增大db_file_multiblock_read_count這個(gè)參數(shù)。 c、db file scattered read,這個(gè)參數(shù)指的是通過(guò)索引來(lái)讀取,同樣可以通過(guò)增加db_file_multiblock_read_count這個(gè)參數(shù)來(lái)提高性能。 d、latch free,與栓相關(guān)的了,需要專(zhuān)門(mén)調(diào)節(jié)。 e、其他參數(shù)可以不非凡觀注。67. 文件說(shuō)明<1>監(jiān)聽(tīng)器日志文件 以8I為例 $ORACLE_HOME/NETWORK/LOG/LISTENER.LOG;<2>. 監(jiān)聽(tīng)器參數(shù)文件 以8I為例 $ORACLE_HOME/NETWORK/ADMIN/LISTENER.ORA;<3>. TNS 連接文件 以8I為例 $ORACLE_HOME/NETWORK/ADMIN/TNSNAMES.ORA;<4>. Sql*Net 環(huán)境文件 以8I為例 $ORACLE_HOME/NETWORK/ADMIN/SQLNET.ORA;<5>. 警告日志文件 以8I為例 $ORACLE_HOME/ADMIN/SID/BDUMP/SIDALRT.LOG;<6>. 基本結(jié)構(gòu) 以8I為例 $ORACLE_HOME/RDBMS/ADMIN/STANDARD.SQL;<7>. 建立數(shù)據(jù)字典視圖 以8I為例 $ORACLE_HOME/RDBMS/ADMIN/CATALOG.SQL;<8>.建立審計(jì)用數(shù)據(jù)字典視圖 以8I為例 $ORACLE_HOME/RDBMS/ADMIN/CATAUDIT.SQL;<9>. 建立快照用數(shù)據(jù)字典視圖 以8I為例 $ORACLE_HOME/RDBMS/ADMIN/CATSNAP.SQL68、oracle 安全與審計(jì) user_sys_privs,user_tab_privs;配置文件 主要參數(shù) session_per_user; 每個(gè)用戶(hù)可同時(shí)進(jìn)行幾個(gè)會(huì)話 cpu_per_session每個(gè)用戶(hù)可用多少個(gè)(cpu的)百分之一秒 cpu_per_call;;;語(yǔ)法分析、執(zhí)行、取數(shù)可用多少個(gè)百分之一秒 connect_time;;;用戶(hù)連接數(shù)據(jù)庫(kù)的時(shí)間(分鐘) idle_time 用戶(hù)不調(diào)用數(shù)據(jù)庫(kù)的時(shí)間(分鐘) logical_reads_per_session; 整個(gè)會(huì)話過(guò)程中用戶(hù)訪問(wèn)oracle的塊數(shù) logical_reads_per_call;;一次調(diào)用用戶(hù)訪問(wèn)oracle的塊數(shù) private_SGA;;;;一個(gè)用戶(hù)進(jìn)程所用SGA的內(nèi)存數(shù)量 composite_limit復(fù)合限制數(shù) failed_login_attempts 連續(xù)多次注冊(cè)失敗引起一個(gè)帳戶(hù)死鎖 passWord_life_time;一個(gè)口令在其終止前可用的天數(shù) password_reuse_time;一個(gè)口令在其n天才能重新使用 password_reuse_max;一個(gè)口令在重新使用之前必須改變多少次 password_lock_time;一個(gè)口令帳戶(hù)被鎖住的天數(shù)69、治理初始化文件 show parameters 經(jīng)常修改的項(xiàng)目有; v$parameter shared_pool_size; 分配給共享的字節(jié)數(shù) rollback_segments 回滾段的個(gè)數(shù) sessions; 會(huì)話個(gè)數(shù) processes 進(jìn)程個(gè)數(shù)70、治理控制文件 控制文件保存文件有關(guān)數(shù)據(jù)庫(kù)創(chuàng)建時(shí)間、數(shù)據(jù)庫(kù)名以及數(shù)據(jù)庫(kù)運(yùn)行時(shí)使用的所有文件位置和名稱(chēng)。 增加控制文件,在initorcl.ora中,找到control_file項(xiàng),增加一項(xiàng)即可 刪除控制文件,在initorcl.ora中去掉,然后刪除物理文件 建立新的控制文件 create controlfile; [reuse] [set] database; 數(shù)據(jù)庫(kù)名; logfile [group 整數(shù)] 文件名 [,[group 整數(shù)] 文件名],... 對(duì)于現(xiàn)有的數(shù)據(jù)庫(kù),可以間接地通過(guò) ;alter database backup; controlfile; to trace命令生成控制文件,即可在orantrmb73trace 下有ora00289.trc文件,其內(nèi)容為文本71、日志治理 <1>建立日志組 sql>select * from v$logfile; sql>alter database add logfile group 3 ('f:orantdatabaselog1_g3.ora' 'f:orantdatabaselog2_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; 但是其物理文件并沒(méi)有被刪除掉 系統(tǒng)至少需要2個(gè)日志組,假如只有2個(gè),就不能刪除 不能刪除正活動(dòng)的日志組 <3>手工歸檔 通過(guò)alter system 的archive log 子句來(lái)實(shí)現(xiàn) archive; log [thread 整數(shù)] [seq 整數(shù)][change 整數(shù)][current][group 整數(shù)] [logfile '文件名'][next][all][start][to '位置'] <4> 強(qiáng)制日志切換 sql> alter system switch logfile; <5> 強(qiáng)制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:oracleoradblog'); c. sql> execute dbms_logmnr_add_logfile('c:oracleoradataoradbredo01.log', sql> dbms_logmnr.new); d. sql> execute dbms_logmnr.add_logfile('c:oracleoradataoradbredo02.log', sql> dbms_logmnr.addfile); e. sql> execute dbms_logmnr.start_logmnr(dictfilename=>'c:oracleoradblogoradb.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 系統(tǒng)控制 alter system ... alter system enable restricted session只答應(yīng)具有restricted系統(tǒng)特權(quán)的用戶(hù)登錄 alter system flush; shared_pool; 清除共享池 alter system checkpoint執(zhí)行一 個(gè)檢查點(diǎn) alter system set license_max_session=64,license_session_warning=54 會(huì)話限制為64,會(huì)話的警界為54 alter system set license_max_session=0 會(huì)話數(shù)為無(wú)限制 alter system set license_max_users=300 用戶(hù)限制為300個(gè) alter system switch logfile; 強(qiáng)制執(zhí)行日志轉(zhuǎn)換73 會(huì)話控制 alter session alter session set sql_trace=true; 當(dāng)前會(huì)話具有sql跟蹤功能 alter session set NLS_language=French 出錯(cuò)信息設(shè)為法語(yǔ) alter session set NLS_date_format='YYYY MM DD HH24:MI:SS';缺省日期格式 alter session set optimizier_goal=first_row改變優(yōu)化方法為基于開(kāi)銷(xiāo)方法,具有快速響應(yīng)速度 update student@teach set sold=sold+1 where sno='98010'; commit; alter session close database link teach; 關(guān)閉遠(yuǎn)程鏈路74、封鎖機(jī)制 數(shù)據(jù)封鎖:保護(hù)表數(shù)據(jù),在多個(gè)用戶(hù)并行存取數(shù)據(jù)時(shí)候,保證數(shù)據(jù)的完整性。 DML操作又在兩個(gè)級(jí)別獲取數(shù)據(jù)封鎖:指定記錄封鎖和表封鎖 表封鎖可以有下列方式:行共享(RS),行排他(RX),共享封鎖(S),共享行排他(SPX)和排他 封鎖(X) 行共享表封鎖(RS),答應(yīng)其他事務(wù)并行查詢(xún)、插入,修改和刪除及再行封鎖 select ...from; 表名; ...; for update of ...; lock table 表名; in row share mode; 行排他表封鎖(RX) 對(duì)該行有獨(dú)占權(quán)利 insert into 表名 ...; update 表名 ...; delete from 表名 ...; lock table 表名 in row exclusive mode; 答應(yīng)并行查詢(xún)、插入、刪除或封鎖其他行,但禁止其他事務(wù)使用下列命令進(jìn)行并發(fā)封鎖: lock table 表名 in share mode; lock table 表名 in share exclusive mode; lock table 表名 in exclusive mode; 共享表封鎖(S) lock table 表名 in share mode; 答應(yīng)其他事務(wù)可在該表上做查詢(xún)和再實(shí)現(xiàn)共享表操作,但不能修改該表,同時(shí)也不能做如下封鎖: 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、設(shè)置事務(wù) set transaction [read only][read write][use rollback segment 回滾段名]76.假如希望用aimtzmcc用戶(hù)連接數(shù)據(jù)庫(kù),訪問(wèn)aicbs用戶(hù)的表,不在表名前綴'aicbs.',可以在建立數(shù)據(jù)庫(kù)連接后發(fā)下面的命令 alter session set current_schema = aicbs;77、表空間治理 <1> 創(chuàng)建表空間sql> create tablespace tablespace_name datafile 'c:oracleoradatafile1.dbf' size 100m, ;sql> 'c:oracleoradatafile2.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:oracleoradatauser_data01.dbf' sql> size 500m extent management local uniform size 10m; <3>.temporary tablespace sql> create temporary tablespace temp tempfile 'c:oracleoradatatemp01.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 onlywrite; <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:oracleoradataapp_data01.dbf' size 200m sql> autoextend on next 10m maxsize 500m; <9>.change the size fo data files manually sql> alter database datafile 'c:oracleoradataapp_data.dbf' resize 200m; <10>.Moving data files: alter tablespace sql> alter tablespace app_data rename datafile 'c:oracleoradataapp_data.dbf' sql> to 'c:oracleapp_data.dbf'; <11>.moving data files:alter database sql> alter database rename file 'c:oracleoradataapp_data.dbf' sql> to 'c:oracleapp_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:backupuser.dbf c:oradatauser.dbf startup mount recover datafile 'c:oradatauser.dbf; alter database open; --method 2(opened database,initially opened,not system or rollback datafile) copy c:backupuser.dbf c:oradatauser.dbf (alter tablespace offline) recover datafile 'c:oradatauser.dbf' or recover tablespace user_data; alter database datafile 'c:oradatauser.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:oradatauser.dbf' offline; alter database open copy c:backupuser.dbf d:oradatauser.dbf alter database rename file 'c:oradatauser.dbf' to 'd:oradatauser.dbf' recover datafile 'e:oradatauser.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:oradatauser.dbf' as 'c:oradatauser.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:oradataredo03.log' size 1000k; alter database drop logfile group 1; alter database open; or >cp c:oradataredo02.log' c:oradataredo01.log alter database clear logfile 'c:oradatalog01.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 openmount,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.查詢(xún)當(dāng)前正在執(zhí)行的job的情況 有時(shí)候?qū)τ谛枰獔?zhí)行的job查詢(xún)執(zhí)行情況,比如正在執(zhí)行那條語(yǔ)句,或者想把job停下來(lái)等。一般不知道怎么查詢(xún)到 job執(zhí)行的session的sid. 方法一: ;select * from dba_jobs_running ;假如運(yùn)行比較慢,加 ;select /*+ rule */* from dba_jobs_running 方法二: <1>首先得到j(luò)ob號(hào),從user_jobs或者dba_jobs ;select * from user_jobs where upper(what) like '%MYPROGRAM%' <2> 根據(jù)job號(hào)查詢(xún)sid號(hào) ;select * from v$lock where id2 = 3361910 and type ='JQ' 就可以查詢(xún)到sid了 比如查詢(xún)當(dāng)前的執(zhí)行什么語(yǔ)句 ;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_address82.怎么樣給sqlplus安裝幫助[A]SQLPLUS的幫助必須手工安裝,shell腳本為$ORACLE_HOME/bin/helpins在安裝之前,必須先設(shè)置SYSTEM_PASS環(huán)境變量,如:$ setenv SYSTEM_PASS SYSTEM/MANAGER $ helpins假如不設(shè)置該環(huán)境變量,將在運(yùn)行腳本的時(shí)候提示輸入環(huán)境變量當(dāng)然,除了shell腳本,還可以利用sql腳本安裝,那就不用設(shè)置環(huán)境變量了,但是,我們必須以system登錄。$ sqlplus system/manager SQL> @?/sqlplus/admin/help/helpbld.sql helpus.sql安裝之后,你就可以象如下的方法使用幫助了SQL> help index83.如何移動(dòng)數(shù)據(jù)文件<1>、關(guān)閉數(shù)據(jù)庫(kù),利用os拷貝a.shutdown immediate關(guān)閉數(shù)據(jù)庫(kù)b.在os下拷貝數(shù)據(jù)文件到新的地點(diǎn)c.Startup mount 啟動(dòng)到mount下d.Alter database rename datafile '老文件' to '新文件';e.Alter database open; 打開(kāi)數(shù)據(jù)庫(kù)<2>、利用Rman聯(lián)機(jī)操作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';說(shuō)明:利用OS拷貝也可以聯(lián)機(jī)操作,不關(guān)閉數(shù)據(jù)庫(kù),與rman的步驟一樣,利用rman與利用os拷貝的原理一樣,在rman中copy是拷貝數(shù)據(jù)文件,相當(dāng)于OS的cp,而switch則相當(dāng)于alter database rename,用來(lái)更新控制文件。84.如何治理聯(lián)機(jī)日志組與成員以下是常見(jiàn)操作,假如在OPA/RAC下注重線程號(hào)增加一個(gè)日志文件組Alter database add logfile [group n] '文件全名' size 10M;在這個(gè)組上增加一個(gè)成員Alter database add logfile member '文件全名' to group n;在這個(gè)組上刪除一個(gè)日志成員Alter database drop logfile member '文件全名';刪除整個(gè)日志組Alter database drop logfile group n;85.怎么樣計(jì)算REDO BLOCK的大小[A]計(jì)算方法為(redo size + redo wastage) / redo blocks written + 16具體見(jiàn)如下例子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)------------------ 51286.假如發(fā)現(xiàn)表中有壞塊,如何檢索其它未壞的數(shù)據(jù)[A]首先需要找到壞塊的ID(可以運(yùn)行dbverify實(shí)現(xiàn)),假設(shè)為,假定文件編碼為。運(yùn)行下面的查詢(xún)查找段名: SELECT segment_name,segment_type,extent_id,block_id, blocks from dba_extents twhere file_id = AND between block_id and (block_id + blocks - 1) 一旦找到壞段名稱(chēng),若段是一個(gè)表,則最好建立一個(gè)臨時(shí)表,存放好的數(shù)據(jù)。若段是索引,則刪除它,再重建。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與現(xiàn)在ROWID的差別。還可以使用診斷事件10231SQL> ALTER SYSTEM SET EVENTS '10231 trace name context forever,level 10';創(chuàng)建一個(gè)臨時(shí)表good_table的表中除壞塊的數(shù)據(jù)都檢索出來(lái)SQL>CREATE TABLE good_table as select * from bad_table;最后關(guān)閉診斷事件SQL> ALTER SYSTEM SET EVENTS '10231 trace name context off ';關(guān)于ROWID的結(jié)構(gòu),還可以參考dbms_rowid.rowid_create函數(shù)87.怎么樣備份控制文件在線備份為一個(gè)二進(jìn)制的文件alter database backup controlfile to '$BACKUP_DEPT/controlfile.000' [reuse];備份為文本文件方式alter database backup controlfile to trace [resetlogsnoresetlogs]; 88.控制文件損壞如何恢復(fù)<1>、假如是損壞單個(gè)控制文件只需要關(guān)閉數(shù)據(jù)庫(kù),拷貝一個(gè)好的數(shù)據(jù)文件覆蓋掉壞的數(shù)據(jù)文件即可或者是修改init.ora文件的相關(guān)部分<2>、假如是損失全部控制文件,則需要?jiǎng)?chuàng)建控制文件或從備份恢復(fù)創(chuàng)建控制文件的腳本可以通過(guò)alter database backup controlfile to trace獲取。89.怎么樣熱備份一個(gè)表空間<1>Alter tablespace 名稱(chēng) begin backup;host cp 這個(gè)表空間的數(shù)據(jù)文件 目的地;Alter tablespace 名稱(chēng) end backup;假如是備份多個(gè)表空間或整個(gè)數(shù)據(jù)庫(kù),只需要一個(gè)一個(gè)表空間的操作下來(lái)就可以了。90.怎么快速得到整個(gè)數(shù)據(jù)庫(kù)的熱備腳本<1>可以寫(xiě)一段類(lèi)似的腳本SQL>set serveroutput onbegindbms_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#) loopdbms_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.丟失一個(gè)數(shù)據(jù)文件,但是沒(méi)有備份,怎么樣打開(kāi)數(shù)據(jù)庫(kù)假如沒(méi)有備份只能是刪除這個(gè)數(shù)據(jù)文件了,會(huì)導(dǎo)致相應(yīng)的數(shù)據(jù)丟失。SQL>startup mount--ARCHIVELOG模式命令SQL>Alter database datafile 'file name' offline;--NOARCHIVELOG模式命令SQL>Alter database datafile 'file name' offline drop;SQLl>Alter database open;注重:該數(shù)據(jù)文件不能是系統(tǒng)數(shù)據(jù)文件92.丟失一個(gè)數(shù)據(jù)文件,沒(méi)有備份但是有該數(shù)據(jù)文件創(chuàng)建以來(lái)的歸檔怎么恢復(fù)保證如下條件a. 不能是系統(tǒng)數(shù)據(jù)文件b. 不能丟失控制文件假如滿(mǎn)足以上條件,則SQL>startup mountSQL>Alter database create datafile 'file name' as 'file name' size ... reuse;SQL>recover datafile n; -文件號(hào)或者SQL>recover datafile 'file name';或者SQL>recover database;SQL>Alter database open;93.聯(lián)機(jī)日志損壞如何恢復(fù)<1>、假如是非當(dāng)前日志而且歸檔,可以使用Alter database clear logfile group n來(lái)創(chuàng)建一個(gè)新的日志文件假如該日志還沒(méi)有歸檔,則需要用Alter database clear unarchived logfile group n<2>、假如是當(dāng)前日志損壞,一般不能clear,則可能意味著丟失數(shù)據(jù)假如有備份,可以采用備份進(jìn)行不完全恢復(fù)假如沒(méi)有備份,可能只能用_allow_resetlogs_corruption=true來(lái)進(jìn)行強(qiáng)制恢復(fù)了,但是,這樣的方法是不建議的,最好在有Oracle support的指導(dǎo)下進(jìn)行。94.怎么樣創(chuàng)建RMAN恢復(fù)目錄首先,創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)用戶(hù),一般都是RMAN,并給予recovery_catalog_owner角色權(quán)限sqlplus sysSQL> 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;然后,用這個(gè)用戶(hù)登錄,創(chuàng)建恢復(fù)目錄rman catalog rman/rmanRMAN> create catalog tablespace tools;RMAN> exit;最后,你可以在恢復(fù)目錄注冊(cè)目標(biāo)數(shù)據(jù)庫(kù)了rman catalog rman/rman target backdba/backdbaRMAN> register database;95.怎么樣在恢復(fù)的時(shí)候移動(dòng)數(shù)據(jù)文件,恢復(fù)到別的地點(diǎn)給一個(gè)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)中恢復(fù)(restore)控制文件與數(shù)據(jù)文件可以使用如下方法,在RMAN中恢復(fù)備份片的控制文件restore controlfile from backuppiecefile;假如是9i的自動(dòng)備份,可以采用如下的方法 restore controlfile from autobackup; 但是,假如控制文件全部丟失,需要指定DBID,如SET DBID=?自動(dòng)備份控制文件的默認(rèn)格式是%F,這個(gè)格式的形式為 c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII就是DBID 至于恢復(fù)(restore)數(shù)據(jù)文件,oracle 816開(kāi)始有個(gè)包dbms_backup_restore 在 nomount 狀態(tài)下就可以執(zhí)行,可以讀 815甚至之前的備份片,讀出來(lái)的文件用于恢復(fù) 可以在SQLPLUS中運(yùn)行,如下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:Oracleoradatapennycontrol01.ctl'); 8 dbms_backup_restore.restoreDataFileto(1,'E:Oracleoradatapennysystem01.dbf'); 9 dbms_backup_restore.restoreDataFileto(2,'E:OracleoradatapennyUNDOTBS01.DBF'); 10 dbms_backup_restore.restoreDataFileto(3,'E:ORACLEORADATAPENNYUSERS01.DBF'); 11 dbms_backup_restore.restorebackuppiece('D:orabakBACKUP_1_4_04F4IAJT.PENNY',done=>done); 12 END; 13 / PL/SQL 過(guò)程已成功完成。 SQL> alter database mount; [Q]Rman的format格式中的%s類(lèi)似的東西代表什么意義[A]可以參考如下%c 備份片的拷貝數(shù) %d 數(shù)據(jù)庫(kù)名稱(chēng) %D 位于該月中的第幾天 (DD) %M 位于該年中的第幾月 (MM) %F 一個(gè)基于DBID唯一的名稱(chēng),這個(gè)格式的形式為c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII為該數(shù)據(jù)庫(kù)的DBID,YYYYMMDD為日期,QQ是一個(gè)1-256的序列 %n 數(shù)據(jù)庫(kù)名稱(chēng),向右填補(bǔ)到最大八個(gè)字符 %u 一個(gè)八個(gè)字符的名稱(chēng)代表備份集與創(chuàng)建時(shí)間 %p 該備份集中的備份片號(hào),從1開(kāi)始到創(chuàng)建的文件數(shù)%U 一個(gè)唯一的文件名,代表%u_%p_%c %s 備份集的號(hào) %t 備份集時(shí)間戳 %T 年月日格式(YYYYMMDD)97.執(zhí)行exec dbms_logmnr_d.build('Logminer.ora','file Directory'),提示下標(biāo)超界,怎么辦完整錯(cuò)誤信息如下,SQL> exec dbms_logmnr_d.build('Logminer.ora','file directory') BEGIN dbms_logmnr_d.build('Logminer.ora','file directory'); END; * ERROR 位于第 1 行: ORA-06532: 下標(biāo)超出限制 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; 為T(mén)YPE col_desc_array IS VARRAY(700) OF col_description; 并保存文件<2>. 運(yùn)行改變后的腳本SQLPLUS> Connect internal SQLPLUS> @$ORACLE_HOME/rdbms/admin/dbmslmd.sql <3>.重新編譯該包SQLPLUS> alter package DBMS_LOGMNR_D compile body;98.執(zhí)行execute dbms_logmnr.start_logmnr(DictFileName=>'DictFileName')提示ORA-01843:無(wú)效的月份,這個(gè)是什么原因我們分析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')失敗,將導(dǎo)致以上錯(cuò)誤所以解決辦法可以為<1>、Alter session set NLS_LANGUAGE=American<2>、用類(lèi)似如下的方法執(zhí)行execute dbms_logmnr.start_logmnr (DictFileName=> 'f:temp2TESTDICT.ora', starttime => TO_DATE( '01-01-1988','DD-MM-YYYY'), endTime=>TO_DATE('01-01-2988','DD-MM-YYYY'));
標(biāo)簽:
Oracle
數(shù)據(jù)庫(kù)
排行榜
