oracle 學習總結(效能優化)
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;
在這個組上刪除一個日誌成員
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) = 1
在這裡要注意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
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/235507/viewspace-557665/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle資料庫效能優化總結Oracle資料庫優化
- 效能優化 - Oracle Tuning 總結 1優化Oracle
- 效能優化總結優化
- oracle 學習筆記---效能優化學習(1)Oracle筆記優化
- 效能優化 - Oracle Tuning 總結 3 優化統計優化Oracle
- Oracle SQL效能優化技巧大總結_水OracleSQL優化
- Oracle效能優化視訊學習筆記-效能優化概念(一)Oracle優化筆記
- Oracle效能優化視訊學習筆記-效能優化概念(二)Oracle優化筆記
- ORACLE學習筆記--效能優化FAQ。Oracle筆記優化
- oracle 學習筆記---效能優化(1)Oracle筆記優化
- oracle 學習筆記---效能優化(2)Oracle筆記優化
- oracle 學習筆記---效能優化(3)Oracle筆記優化
- oracle 學習筆記---效能優化(4)Oracle筆記優化
- oracle 學習筆記---效能優化(5)Oracle筆記優化
- oracle 學習筆記---效能優化(6)Oracle筆記優化
- oracle 學習筆記---效能優化(7)Oracle筆記優化
- React 效能優化總結React優化
- canvas效能優化總結Canvas優化
- React效能優化總結React優化
- 前端效能優化總結前端優化
- iOS 效能優化總結iOS優化
- 效能優化 - Oracle Tuning 總結 2-2優化Oracle
- Oracle 效能優化小結Oracle優化
- Android效能優化——效能優化的難題總結Android優化
- 小程式效能優化總結優化
- App瘦身、效能優化總結APP優化
- 系統效能優化總結優化
- 前端效能優化常用總結前端優化
- web前端效能優化總結Web前端優化
- Android效能優化總結Android優化
- 效能優化 - Oracle Tuning 總結 2-1 Statspack優化Oracle
- 深度學習優化演算法總結深度學習優化演算法
- Oracle學習系列—資料庫優化—效能優化工具Oracle資料庫優化
- Oracle SQL優化總結OracleSQL優化
- Oracle SQL優化 總結OracleSQL優化
- oracle performance tuning效能優化學習系列(三)OracleORM優化
- oracle performance tuning效能優化學習系列(五)OracleORM優化
- oracle performance tuning效能優化學習系列(四)OracleORM優化