我的oracle笔记四(DBA管理)

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 <

/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 <

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)/(10241024) 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=

  1<sid>;   
  2Select * from v$sqltext where address=<sql_address>;   
  3执行以上两个语句便可以得到这个session的语句。   
  4你也以用alter system kill session 'sid,serial#';把这个session杀掉。   
  5&lt;3&gt; 应观注一下event这列,这是我们调优的关键一列,下面对常出现的event做以简要的说明:   
  6a、buffer busy waits,free buffer waits这两个参数所标识是dbwr是否够用的问题,与IO很大相关的,当v$session_wait中的free buffer wait的条目很小或没有的时侯,说明你的系统的dbwr进程决对够用,不用调整;free buffer wait的条目很多,你的系统感觉起来一定很慢,这时说明你的dbwr已经不够用了,它产生的wio已经成为你的数据库性能的瓶颈,这时的解决办法如下:   
  7a.1增加写进程,同时要调整db_block_lru_latches参数   
  8示例:修改或添加如下两个参数   
  9db_writer_processes=4   
 10db_block_lru_latches=8   
 11a.2开异步IO,IBM这方面简单得多,hp则麻烦一些,可以与Hp工程师联系。   
 12b、db file sequential read,指的是顺序读,即全表扫描,这也是我们应该尽量减少的部分,解决方法就是使用索引、sql调优,同时可以增大db_file_multiblock_read_count这个参数。   
 13c、db file scattered read,这个参数指的是通过索引来读取,同样可以通过增加db_file_multiblock_read_count这个参数来提高性能。   
 14d、latch free,与栓相关的了,需要专门调节。   
 15e、其他参数可以不特别观注。 
 16
 1767\. 文件说明   
 18&lt;1&gt;监听器日志文件   
 19以8I为例   
 20$ORACLE_HOME/NETWORK/LOG/LISTENER.LOG 
 21
 22&lt;2&gt;. 监听器参数文件   
 23以8I为例   
 24$ORACLE_HOME/NETWORK/ADMIN/LISTENER.ORA 
 25
 26&lt;3&gt;. TNS 连接文件   
 27以8I为例   
 28$ORACLE_HOME/NETWORK/ADMIN/TNSNAMES.ORA 
 29
 30&lt;4&gt;. Sql*Net 环境文件   
 31以8I为例   
 32$ORACLE_HOME/NETWORK/ADMIN/SQLNET.ORA 
 33
 34&lt;5&gt;. 警告日志文件   
 35以8I为例   
 36$ORACLE_HOME/ADMIN/SID/BDUMP/SIDALRT.LOG 
 37
 38&lt;6&gt;. 基本结构   
 39以8I为例   
 40$ORACLE_HOME/RDBMS/ADMIN/STANDARD.SQL 
 41
 42&lt;7&gt;. 建立数据字典视图   
 43以8I为例   
 44$ORACLE_HOME/RDBMS/ADMIN/CATALOG.SQL 
 45
 46&lt;8&gt;.建立审计用数据字典视图   
 47以8I为例   
 48$ORACLE_HOME/RDBMS/ADMIN/CATAUDIT.SQL 
 49
 50&lt;9&gt;. 建立快照用数据字典视图   
 51以8I为例   
 52$ORACLE_HOME/RDBMS/ADMIN/CATSNAP.SQL 
 53
 5468、oracle 安全与审计   
 55user_sys_privs,user_tab_privs;   
 56配置文件   
 57主要参数   
 58session_per_user 每个用户可同时进行几个会话   
 59cpu_per_session 每个用户可用多少个(cpu的)百分之一秒   
 60cpu_per_call 语法分析、执行、取数可用多少个百分之一秒   
 61connect_time 用户连接数据库的时间(分钟)   
 62idle_time 用户不调用数据库的时间(分钟)   
 63logical_reads_per_session 整个会话过程中用户访问oracle的块数   
 64logical_reads_per_call 一次调用用户访问oracle的块数   
 65private_SGA 一个用户进程所用SGA的内存数量   
 66composite_limit 复合限制数   
 67failed_login_attempts 连续多次注册失败引起一个帐户死锁   
 68password_life_time 一个口令在其终止前可用的天数   
 69password_reuse_time 一个口令在其n天才能重新使用   
 70password_reuse_max 一个口令在重新使用之前必须改变多少次   
 71password_lock_time 一个口令帐户被锁住的天数   
 7269、管理初始化文件   
 73show parameters   
 74经常修改的项目有 v$parameter   
 75shared_pool_size 分配给共享的字节数   
 76rollback_segments 回滚段的个数   
 77sessions 会话个数   
 78processes 进程个数   
 7970、管理控制文件   
 80控制文件保存文件有关数据库创建时间、数据库名以及数据库运行时使用的所有文件位置和名称。   
 81增加控制文件,在initorcl.ora中,找到control_file项,增加一项即可   
 82删除控制文件,在initorcl.ora中去掉,然后删除物理文件   
 83建立新的控制文件   
 84create controlfile [reuse] [set] database 数据库名   
 85logfile [group 整数] 文件名 [,[group 整数] 文件名],...   
 86对于现有的数据库,可以间接地通过   
 87alter database backup controlfile to trace命令生成控制文件,即可在\orant\rmb73\trace   
 88下有ora00289.trc文件,其内容为文本 
 89
 9071、日志管理   
 91&lt;1&gt;建立日志组   
 92sql&gt;select * from v$logfile;   
 93sql&gt;alter database add logfile group 3   
 94('f:\orant\database\log1_g3.ora'   
 95'f:\orant\database\log2_g3.ora') size 100k;   
 96sql&gt;select * from v$logfile; 
 97
 98\----   
 99sql&gt; alter database add logfile group 4   
100('/disk3/log4a.rdo','/disk4/log4b.rdo') size 1m; 
101
102&lt;2&gt;删除日志组   
103alter database drop logfile group 1;   
104但是其物理文件并没有被删除掉   
105系统至少需要2个日志组,如果只有2个,就不能删除   
106不能删除正活动的日志组   
107&lt;3&gt;手工归档   
108通过alter system 的archive log 子句来实现   
109archive log [thread 整数]   
110[seq 整数][change 整数][current][group 整数]   
111[logfile '文件名'][next][all][start][to '位置']   
112&lt;4&gt; 强制日志切换   
113sql&gt; alter system switch logfile;   
114&lt;5&gt; 强制checkpoints   
115sql&gt; alter system checkpoint;   
116&lt;6&gt; adding online redo log members   
117sql&gt;alter database add logfile member   
118'/disk3/log1b.rdo' to group 1,   
119'/disk4/log2b.rdo' to group 2;   
120&lt;7&gt;.changes the name of the online redo logfile   
121sql&gt; alter database rename file 'c:/oracle/oradata/oradb/redo01.log'   
122to 'c:/oracle/oradata/redo01.log';   
123&lt;8&gt; drop online redo log members   
124sql&gt; alter database drop logfile member 'c:/oracle/oradata/redo01.log';   
125&lt;9&gt;.clearing online redo log files   
126sql&gt; alter database clear [unarchived] logfile 'c:/oracle/log2a.rdo';   
127&lt;10&gt;.using logminer analyzing redo logfiles   
128a. in the init.ora specify utl_file_dir = ' '   
129b. sql&gt; execute dbms_logmnr_d.build('oradb.ora','c:\oracle\oradb\log');   
130c. sql&gt; execute dbms_logmnr_add_logfile('c:\oracle\oradata\oradb\redo01.log',   
131sql&gt; dbms_logmnr.new);   
132d. sql&gt; execute dbms_logmnr.add_logfile('c:\oracle\oradata\oradb\redo02.log',   
133sql&gt; dbms_logmnr.addfile);   
134e. sql&gt; execute dbms_logmnr.start_logmnr(dictfilename=&gt;'c:\oracle\oradb\log\oradb.ora');   
135f. sql&gt; select * from v$logmnr_contents(v$logmnr_dictionary,v$logmnr_parameters   
136sql&gt; v$logmnr_logs);   
137g. sql&gt; execute dbms_logmnr.end_logmnr; 
138
139  
14072 系统控制   
141alter system ...   
142  
143alter system enable restricted session; 只允许具有restricted系统特权的用户登录   
144alter system flush shared_pool 清除共享池   
145alter system checkpoint 执行一 个检查点   
146alter system set license_max_session=64,license_session_warning=54 会话限制为64,会话的警界为54   
147alter system set license_max_session=0 会话数为无限制   
148alter system set license_max_users=300 用户限制为300个   
149alter system switch logfile 强制执行日志转换   
15073 会话控制   
151alter session   
152  
153alter session set sql_trace=true 当前会话具有sql跟踪功能   
154alter session set NLS_language=French 出错信息设为法语   
155alter session set NLS_date_format='YYYY MM DD HH24:MI:SS';缺省日期格式   
156alter session set optimizier_goal=first_row改变优化方法为基于开销方法,具有快速响应速度   
157update student@teach set sold=sold+1 where sno='98010';   
158commit;   
159alter session close database link teach; 关闭远程链路   
16074、封锁机制   
161数据封锁:保护表数据,在多个用户并行存取数据时候,保证数据的完整性。   
162DML操作又在两个级别获取数据封锁:指定记录封锁和表封锁   
163表封锁可以有下列方式:行共享(RS),行排他(RX),共享封锁(S),共享行排他(SPX)和排他   
164封锁(X)   
165行共享表封锁(RS),允许其他事务并行查询、插入,修改和删除及再行封锁   
166select ...from 表名 ... for update of ...;   
167lock table 表名 in row share mode;   
168行排他表封锁(RX) 对该行有独占权利   
169insert into 表名 ...;   
170update 表名 ...;   
171delete from 表名 ...;   
172lock table 表名 in row exclusive mode;   
173允许并行查询、插入、删除或封锁其他行,但禁止其他事务使用下列命令进行并发封锁:   
174lock table 表名 in share mode;   
175lock table 表名 in share exclusive mode;   
176lock table 表名 in exclusive mode;   
177共享表封锁(S)   
178lock table 表名 in share mode;   
179允许其他事务可在该表上做查询和再实现共享表操作,但不能修改该表,同时也不能做如下封锁:   
180lock table 表名 in share row exclusive mode;   
181lock table 表名 in exclusive mode;   
182lock table 表名 in row exclusive mode;   
183共享排他表封锁(SRX)   
184lock table 表名 in share row exclusive mode;   
185排他表封锁(SRX)   
186lock table 表名 in exclusive mode; 
187
188  
18975、设置事务   
190set transaction [read only][read write][use rollback segment 回滚段名] 
191
19276.如果希望用aimtzmcc用户连接数据库,访问aicbs用户的表,不在表名前缀"aicbs.",可以在建立数据库连接后发下面的命令   
193alter session set current_schema = aicbs; 
194
19577、表空间管理   
196&lt;1&gt; 创建表空间   
197sql&gt; create tablespace tablespace_name datafile 'c:\oracle\oradata\file1.dbf' size 100m,   
198sql&gt; 'c:\oracle\oradata\file2.dbf' size 100m minimum extent 550k [logging/nologging]   
199sql&gt; default storage (initial 500k next 500k maxextents 500 pctinccease 0)   
200sql&gt; [online/offline] [permanent/temporary] [extent_management_clause]   
201&lt;2&gt;.locally managed tablespace   
202sql&gt; create tablespace user_data datafile 'c:\oracle\oradata\user_data01.dbf'   
203sql&gt; size 500m extent management local uniform size 10m;   
204&lt;3&gt;.temporary tablespace   
205sql&gt; create temporary tablespace temp tempfile 'c:\oracle\oradata\temp01.dbf'   
206sql&gt; size 500m extent management local uniform size 10m;   
207&lt;4&gt;.change the storage setting   
208sql&gt; alter tablespace app_data minimum extent 2m;   
209sql&gt; alter tablespace app_data default storage(initial 2m next 2m maxextents 999);   
210&lt;5&gt;.taking tablespace offline or online   
211sql&gt; alter tablespace app_data offline;   
212sql&gt; alter tablespace app_data online;   
213&lt;6&gt;.read_only tablespace   
214sql&gt; alter tablespace app_data read only|write;   
215&lt;7&gt;.droping tablespace   
216sql&gt; drop tablespace app_data including contents;   
217&lt;8&gt;.enableing automatic extension of data files   
218sql&gt; alter tablespace app_data add datafile 'c:\oracle\oradata\app_data01.dbf' size 200m   
219sql&gt; autoextend on next 10m maxsize 500m;   
220&lt;9&gt;.change the size fo data files manually   
221sql&gt; alter database datafile 'c:\oracle\oradata\app_data.dbf' resize 200m;   
222&lt;10&gt;.Moving data files: alter tablespace   
223sql&gt; alter tablespace app_data rename datafile 'c:\oracle\oradata\app_data.dbf'   
224sql&gt; to 'c:\oracle\app_data.dbf';   
225&lt;11&gt;.moving data files:alter database   
226sql&gt; alter database rename file 'c:\oracle\oradata\app_data.dbf'   
227sql&gt; to 'c:\oracle\app_data.dbf'; 
228
22978、BACKUP and RECOVERY 
230
231&lt;1&gt;. v$sga,v$instance,v$process,v$bgprocess,v$database,v$datafile,v$sgastat 
232
233&lt;2&gt;. Rman need set dbwr_IO_slaves or backup_tape_IO_slaves and large_pool_size 
234
235&lt;3&gt;. Monitoring Parallel Rollback   
236v$fast_start_servers , v$fast_start_transactions 
237
238&lt;4&gt;.perform a closed database backup (noarchivelog)   
239shutdown immediate   
240cp files /backup/   
241startup 
242
243&lt;5&gt;.restore to a different location   
244connect system/manager as sysdba   
245startup mount   
246alter database rename file '/disk1/../user.dbf' to '/disk2/../user.dbf';   
247alter database open; 
248
249&lt;6&gt;.recover syntax   
250\--recover a mounted database   
251recover database;   
252recover datafile '/disk1/data/df2.dbf';   
253alter database recover database;   
254\--recover an opened database   
255recover tablespace user_data;   
256recover datafile 2;   
257alter database recover datafile 2; 
258
259&lt;7&gt;.how to apply redo log files automatically   
260set autorecovery on   
261recover automatic datafile 4; 
262
263&lt;8&gt;.complete recovery:   
264\--method 1(mounted databae)   
265copy c:\backup\user.dbf c:\oradata\user.dbf   
266startup mount   
267recover datafile 'c:\oradata\user.dbf;   
268alter database open;   
269\--method 2(opened database,initially opened,not system or rollback datafile)   
270copy c:\backup\user.dbf c:\oradata\user.dbf (alter tablespace offline)   
271recover datafile 'c:\oradata\user.dbf' or   
272recover tablespace user_data;   
273alter database datafile 'c:\oradata\user.dbf' online or   
274alter tablespace user_data online;   
275\--method 3(opened database,initially closed not system or rollback datafile)   
276startup mount   
277alter database datafile 'c:\oradata\user.dbf' offline;   
278alter database open   
279copy c:\backup\user.dbf d:\oradata\user.dbf   
280alter database rename file 'c:\oradata\user.dbf' to 'd:\oradata\user.dbf'   
281recover datafile 'e:\oradata\user.dbf' or recover tablespace user_data;   
282alter tablespace user_data online;   
283\--method 4(loss of data file with no backup and have all archive log)   
284alter tablespace user_data offline immediate;   
285alter database create datafile 'd:\oradata\user.dbf' as 'c:\oradata\user.dbf''   
286recover tablespace user_data;   
287alter tablespace user_data online   
288&lt;9&gt;.perform an open database backup   
289alter tablespace user_data begin backup;   
290copy files /backup/   
291alter database datafile '/c:/../data.dbf' end backup;   
292alter system switch logfile;   
293&lt;10&gt;.backup a control file   
294alter database backup controlfile to 'control1.bkp';   
295alter database backup controlfile to trace;   
296&lt;11&gt;.recovery (noarchivelog mode)   
297shutdown abort   
298cp files   
299startup   
300&lt;12&gt;.recovery of file in backup mode   
301alter database datafile 2 end backup; 
302
303&lt;13&gt;.clearing redo log file   
304alter database clear unarchived logfile group 1;   
305alter database clear unarchived logfile group 1 unrecoverable datafile; 
306
307&lt;14&gt;.redo log recovery   
308alter database add logfile group 3 'c:\oradata\redo03.log' size 1000k;   
309alter database drop logfile group 1;   
310alter database open;   
311or &gt;cp c:\oradata\redo02.log' c:\oradata\redo01.log   
312alter database clear logfile 'c:\oradata\log01.log'; 
313
31479 managing password security and resources 
315
316&lt;1&gt;.controlling account lock and password   
317sql&gt; alter user juncky identified by oracle account unlock; 
318
319&lt;2&gt;.user_provided password function   
320sql&gt; function_name(userid in varchar2(30),password in varchar2(30),   
321old_password in varchar2(30)) return boolean 
322
323&lt;3&gt;.create a profile : password setting   
324sql&gt; create profile grace_5 limit failed_login_attempts 3   
325sql&gt; password_lock_time unlimited password_life_time 30   
326sql&gt;password_reuse_time 30 password_verify_function verify_function   
327sql&gt; password_grace_time 5; 
328
329&lt;4&gt;.altering a profile   
330sql&gt; alter profile default failed_login_attempts 3   
331sql&gt; password_life_time 60 password_grace_time 10; 
332
333&lt;5&gt;.drop a profile   
334sql&gt; drop profile grace_5 [cascade]; 
335
336&lt;6&gt;.create a profile : resource limit   
337sql&gt; create profile developer_prof limit sessions_per_user 2   
338sql&gt; cpu_per_session 10000 idle_time 60 connect_time 480; 
339
340&lt;7&gt;. view =&gt; resource_cost : alter resource cost   
341dba_Users,dba_profiles 
342
343&lt;8&gt;. enable resource limits   
344sql&gt; alter system set resource_limit=true; 
345
346  
34780.managing privileges 
348
349&lt;1&gt;.system privileges: view =&gt; system_privilege_map ,dba_sys_privs,session_privs 
350
351&lt;2&gt;.grant system privilege   
352sql&gt; grant create session,create table to managers;   
353sql&gt; grant create session to scott with admin option;   
354with admin option can grant or revoke privilege from any user or role; 
355
356&lt;3&gt;.sysdba and sysoper privileges:   
357sysoper: startup,shutdown,alter database open|mount,alter database backup controlfile,   
358alter tablespace begin/end backup,recover database   
359alter database archivelog,restricted session   
360sysdba: sysoper privileges with admin option,create database,recover database until 
361
362&lt;4&gt;.password file members: view:=&gt; v$pwfile_users 
363
364&lt;5&gt;.O7_dictionary_accessibility =true restriction access to view or tables in other schema 
365
366&lt;6&gt;.revoke system privilege   
367sql&gt; revoke create table from karen;   
368sql&gt; revoke create session from scott; 
369
370&lt;7&gt;.grant object privilege   
371sql&gt; grant execute on dbms_pipe to public;   
372sql&gt; grant update(first_name,salary) on employee to karen with grant option; 
373
374&lt;8&gt;.display object privilege : view =&gt; dba_tab_privs, dba_col_privs 
375
376&lt;9&gt;.revoke object privilege   
377sql&gt; revoke execute on dbms_pipe from scott [cascade constraints]; 
378
379&lt;10&gt;.audit record view :=&gt; sys.aud$ 
380
381&lt;11&gt;. protecting the audit trail   
382sql&gt; audit delete on sys.aud$ by access; 
383
384&lt;12&gt;.statement auditing   
385sql&gt; audit user; 
386
387&lt;13&gt;.privilege auditing   
388sql&gt; audit select any table by summit by access; 
389
390&lt;14&gt;.schema object auditing   
391sql&gt; audit lock on summit.employee by access whenever successful; 
392
393&lt;15&gt;.view audit option : view=&gt; all_def_audit_opts,dba_stmt_audit_opts,dba_priv_audit_opts,dba_obj_audit_opts 
394
395&lt;16&gt;.view audit result: view=&gt; dba_audit_trail,dba_audit_exists,dba_audit_object,dba_audit_session,dba_audit_statement 
396
39781 manager role 
398
399&lt;1&gt;.create roles   
400sql&gt; create role sales_clerk;   
401sql&gt; create role hr_clerk identified by bonus;   
402sql&gt; create role hr_manager identified externally; 
403
404&lt;2&gt;.modify role   
405sql&gt; alter role sales_clerk identified by commission;   
406sql&gt; alter role hr_clerk identified externally;   
407sql&gt; alter role hr_manager not identified; 
408
409&lt;3&gt;.assigning roles   
410sql&gt; grant sales_clerk to scott;   
411sql&gt; grant hr_clerk to hr_manager;   
412sql&gt; grant hr_manager to scott with admin option; 
413
414&lt;4&gt;.establish default role   
415sql&gt; alter user scott default role hr_clerk,sales_clerk;   
416sql&gt; alter user scott default role all;   
417sql&gt; alter user scott default role all except hr_clerk;   
418sql&gt; alter user scott default role none; 
419
420&lt;5&gt;.enable and disable roles   
421sql&gt; set role hr_clerk;   
422sql&gt; set role sales_clerk identified by commission;   
423sql&gt; set role all except sales_clerk;   
424sql&gt; set role none; 
425
426&lt;6&gt;.remove role from user   
427sql&gt; revoke sales_clerk from scott;   
428sql&gt; revoke hr_manager from public; 
429
430&lt;7&gt;.remove role   
431sql&gt; drop role hr_manager; 
432
433&lt;8&gt;.display role information   
434view: =&gt;dba_roles,dba_role_privs,role_role_privs,dba_sys_privs,role_sys_privs,role_tab_privs,session_roles 
435
436  
43781.查询当前正在执行的job的情况   
438有时候对于需要执行的job查询执行情况,比如正在执行那条语句,或者想把job停下来等。一般不知道怎么查询到   
439job执行的session的sid.   
440方法一:   
441select * from dba_jobs_running   
442如果运行比较慢,加   
443select /*+ rule */* from dba_jobs_running   
444方法二:   
445&lt;1&gt;首先得到job号,从user_jobs或者dba_jobs   
446select * from user_jobs where upper(what) like '%MYPROGRAM%'   
447&lt;2&gt; 根据job号查询sid号   
448select * from v$lock where id2 = 3361910 and type ='JQ'   
449就可以查询到sid了   
450比如查询当前的执行什么语句   
451select sql_text from v$sqlarea a,v$lock b,v$session c,user_jobs d   
452where d.upper(what) like '%2004PRESENT%'   
453and d.job = b.id2   
454and b.type='JQ'   
455and b.sid = c.sid   
456and a.hash_value = c.sql_hash_value   
457and a.address = c.sql_address 
458
45982.怎么样给sqlplus安装帮助   
460[A]SQLPLUS的帮助必须手工安装,shell脚本为$ORACLE_HOME/bin/helpins   
461在安装之前,必须先设置SYSTEM_PASS环境变量,如:   
462$ setenv SYSTEM_PASS SYSTEM/MANAGER   
463$ helpins   
464如果不设置该环境变量,将在运行脚本的时候提示输入环境变量   
465当然,除了shell脚本,还可以利用sql脚本安装,那就不用设置环境变量了,但是,我们必须以system登录。   
466$ sqlplus system/manager   
467SQL&gt; @?/sqlplus/admin/help/helpbld.sql helpus.sql   
468安装之后,你就可以象如下的方法使用帮助了   
469SQL&gt; help index 
470
47183.如何移动数据文件   
472&lt;1&gt;、关闭数据库,利用os拷贝   
473a.shutdown immediate关闭数据库   
474b.在os下拷贝数据文件到新的地点   
475c.Startup mount 启动到mount下   
476d.Alter database rename datafile '老文件' to '新文件';   
477e.Alter database open; 打开数据库   
478&lt;2&gt;、利用Rman联机操作   
479RMAN&gt; sql "alter database datafile ''file name'' offline";   
480RMAN&gt; run {   
4812&gt; copy datafile 'old file location'   
4823&gt; to 'new file location';   
4834&gt; switch datafile ' old file location'   
4845&gt; to datafilecopy ' new file location';   
4856&gt; }   
486RMAN&gt; sql "alter database datafile ''file name'' online";   
487说明:利用OS拷贝也可以联机操作,不关闭数据库,与rman的步骤一样,利用rman与利用os拷贝的原理一样,在rman中copy是拷贝数据文件,相当于OS的cp,而switch则相当于alter database rename,用来更新控制文件。 
488
48984.如何管理联机日志组与成员   
490以下是常见操作,如果在OPA/RAC下注意线程号   
491增加一个日志文件组   
492Alter database add logfile [group n] '文件全名' size 10M;   
493在这个组上增加一个成员   
494Alter database add logfile member '文件全名' to group n;   
495在这个组上删除一个日志成员   
496Alter database drop logfile member '文件全名';   
497删除整个日志组   
498Alter database drop logfile group n; 
499
50085.怎么样计算REDO BLOCK的大小   
501[A]计算方法为(redo size + redo wastage) / redo blocks written + 16   
502具体见如下例子   
503SQL&gt; select name ,value from v$sysstat where name like '%redo%';   
504NAME VALUE   
505\---------------------------------------------------------------- ----------   
506redo synch writes 2   
507redo synch time 0   
508redo entries 76   
509redo size 19412   
510redo buffer allocation retries 0   
511redo wastage 5884   
512redo writer latching time 0   
513redo writes 22   
514redo blocks written 51   
515redo write time 0   
516redo log space requests 0   
517redo log space wait time 0   
518redo log switch interrupts 0   
519redo ordering marks 0   
520SQL&gt; select (19412+5884)/51 + 16 '"Redo black(byte)" from dual;   
521Redo black(byte)   
522\------------------   
523512 
524
52586.如果发现表中有坏块,如何检索其它未坏的数据   
526[A]首先需要找到坏块的ID(可以运行dbverify实现),假设为,假定文件编码为。运行下面的查询查找段名:   
527SELECT segment_name,segment_type,extent_id,block_id, blocks   
528from dba_extents t   
529where   
530file_id =   
531AND between block_id and (block_id + blocks - 1)   
532一旦找到坏段名称,若段是一个表,则最好建立一个临时表,存放好的数据。若段是索引,则删除它,再重建。   
533create table good_table   
534as   
535select from bad_table where rowid not in   
536(select rowid   
537from bad_table where substr(rowid,10,6) = )   
538在这里要注意8以前的受限ROWID与现在ROWID的差别。   
539还可以使用诊断事件10231   
540SQL&gt; ALTER SYSTEM SET EVENTS '10231 trace name context forever,level 10';   
541创建一个临时表good_table的表中除坏块的数据都检索出来   
542SQL&gt;CREATE TABLE good_table as select * from bad_table;   
543最后关闭诊断事件   
544SQL&gt; ALTER SYSTEM SET EVENTS '10231 trace name context off ';   
545关于ROWID的结构,还可以参考dbms_rowid.rowid_create函数 
546
54787.怎么样备份控制文件   
548在线备份为一个二进制的文件   
549alter database backup controlfile to '$BACKUP_DEPT/controlfile.000' [reuse];   
550备份为文本文件方式   
551alter database backup controlfile to trace [resetlogs|noresetlogs]; 
552
55388.控制文件损坏如何恢复   
554&lt;1&gt;、如果是损坏单个控制文件   
555只需要关闭数据库,拷贝一个好的数据文件覆盖掉坏的数据文件即可   
556或者是修改init.ora文件的相关部分   
557&lt;2&gt;、如果是损失全部控制文件,则需要创建控制文件或从备份恢复   
558创建控制文件的脚本可以通过alter database backup controlfile to trace获取。 
559
56089.怎么样热备份一个表空间   
561&lt;1&gt;Alter tablespace 名称 begin backup;   
562host cp 这个表空间的数据文件 目的地;   
563Alter tablespace 名称 end backup;   
564如果是备份多个表空间或整个数据库,只需要一个一个表空间的操作下来就可以了。 
565
56690.怎么快速得到整个数据库的热备脚本   
567&lt;1&gt;可以写一段类似的脚本   
568SQL&gt;set serveroutput on   
569begin   
570dbms_output.enable(10000);   
571for bk_ts in (select distinct t.ts#,t.name from v$tablespace t,v$datafile d where t.ts#=d.ts#) loop   
572dbms_output.put_line('--'||bk_ts.name);   
573dbms_output.put_line('alter tablespace '||bk_ts.name||' begin backup;');   
574for bk_file in (select file#,name from v$datafile where ts#=bk_ts.ts#) loop   
575dbms_output.put_line('host cp '||bk_file.name||' $BACKUP_DEPT/');   
576end loop;   
577dbms_output.put_line('alter tablespace '||bk_ts.name||' end backup;');   
578end loop;   
579end;   
580/ 
581
58291.丢失一个数据文件,但是没有备份,怎么样打开数据库   
583如果没有备份只能是删除这个数据文件了,会导致相应的数据丢失。   
584SQL&gt;startup mount   
585\--ARCHIVELOG模式命令   
586SQL&gt;Alter database datafile 'file name' offline;   
587\--NOARCHIVELOG模式命令   
588SQL&gt;Alter database datafile 'file name' offline drop;   
589SQLl&gt;Alter database open;   
590注意:该数据文件不能是系统数据文件 
591
59292.丢失一个数据文件,没有备份但是有该数据文件创建以来的归档怎么恢复   
593保证如下条件   
594a. 不能是系统数据文件   
595b. 不能丢失控制文件   
596如果满足以上条件,则   
597SQL&gt;startup mount   
598SQL&gt;Alter database create datafile 'file name' as 'file name' size ... reuse;   
599SQL&gt;recover datafile n; -文件号   
600或者   
601SQL&gt;recover datafile 'file name';   
602或者   
603SQL&gt;recover database;   
604SQL&gt;Alter database open; 
605
60693.联机日志损坏如何恢复   
607&lt;1&gt;、如果是非当前日志而且归档,可以使用   
608Alter database clear logfile group n来创建一个新的日志文件   
609如果该日志还没有归档,则需要用   
610Alter database clear unarchived logfile group n   
611&lt;2&gt;、如果是当前日志损坏,一般不能clear,则可能意味着丢失数据   
612如果有备份,可以采用备份进行不完全恢复   
613如果没有备份,可能只能用_allow_resetlogs_corruption=true来进行强制恢复了,但是,这样的方法是不建议的,最好在有Oracle support的指导下进行。 
614
61594.怎么样创建RMAN恢复目录   
616首先,创建一个数据库用户,一般都是RMAN,并给予recovery_catalog_owner角色权限   
617sqlplus sys   
618SQL&gt; create user rman identified by rman;   
619SQL&gt; alter user rman default tablespace tools temporary tablespace temp;   
620SQL&gt; alter user rman quota unlimited on tools;   
621SQL&gt; grant connect, resource, recovery_catalog_owner to rman;   
622SQL&gt; exit;   
623然后,用这个用户登录,创建恢复目录   
624rman catalog rman/rman   
625RMAN&gt; create catalog tablespace tools;   
626RMAN&gt; exit;   
627最后,你可以在恢复目录注册目标数据库了   
628rman catalog rman/rman target backdba/backdba   
629RMAN&gt; register database; 
630
63195.怎么样在恢复的时候移动数据文件,恢复到别的地点   
632给一个RMAN的例子   
633run {   
634set until time 'Jul 01 1999 00:05:00';   
635allocate channel d1 type disk;   
636set newname for datafile '/u04/oracle/prod/sys1prod.dbf'   
637to '/u02/oracle/prod/sys1prod.dbf';   
638set newname for datafile '/u04/oracle/prod/usr1prod.dbf'   
639to '/u02/oracle/prod/usr1prod.dbf';   
640set newname for datafile '/u04/oracle/prod/tmp1prod.dbf'   
641to '/u02/oracle/prod/tmp1prod.dbf';   
642restore controlfile to '/u02/oracle/prod/ctl1prod.ora';   
643replicate controlfile from '/u02/oracle/prod/ctl1prod.ora';   
644restore database;   
645sql "alter database mount";   
646switch datafile all;   
647recover database;   
648sql "alter database open resetlogs";   
649release channel d1;   
650}   
65196.怎么从备份片(backuppiece)中恢复(restore)控制文件与数据文件   
652可以使用如下方法,在RMAN中恢复备份片的控制文件   
653restore controlfile from backuppiecefile;   
654如果是9i的自动备份,可以采用如下的方法   
655restore controlfile from autobackup;   
656但是,如果控制文件全部丢失,需要指定DBID,如SET DBID=?   
657自动备份控制文件的默认格式是%F,这个格式的形式为   
658c-IIIIIIII</sql_address></sid>
Published At
Categories with 数据库类
Tagged with
comments powered by Disqus