1、通常Oracle需要启动OracleServiceORCL,OracleStartORCL,OracleTNSListener 任务 在NT上至少要启动两个服务 oraclestartID和oracleserverID 每个数据库都有一个系统标识符(SID),典型安装的数据库使用的系统标识符是ORCL2、启动关闭数据库 关闭: 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, 表示客户端的字符集的设置,可能是参数文件,环境变量或者是注册表
O.OWNER'.'O.OBJECT_NAME' ('O.OBJECT_TYPE')', S.TYPE LOCK_TYPE, L.ID1 LOCK_ID1, L.ID2 LOCK_ID2 FROM V$LOCK L, SYS.DBA_OBJECTS O, V$SESSION S WHERE L.SID = S.SID AND L.ID1 = O.OBJECT_ID ;9. 怎样查得数据库的SID ? select name from v$database; 也可以直接查看 init.ora文件10、治理回滚段: 存放事务的恢复信息 建立回滚段 create public rollback segment SEG_NAME tabelspace TABLESPACE_NAME; alter rollback segment SEG_NAME online; 删除回滚段 首先改变为offline状态 直接使用回滚段 sql>set transaction use rollback segment SEG_NAME;11. 计算一个表占用的空间的大小 select owner,table_name, NUM_ROWS, BLOCKS*AAA/1024/1024 "Size M", EMPTY_BLOCKS, LAST_ANALYZED from dba_tables where table_name='XXX'; Here: AAA is the value of db_block_size ; XXX is the table name you want to check 12. 表在表空间中的存储情况 select segment_name,sum(bytes),count(*) ext_quan from dba_extents where tablespace_name='&tablespace_name' and segment_type='TABLE' group by tablespace_name,segment_name; 13. 索引在表空间中的存储情况 select segment_name,count(*) from dba_extents where segment_type='INDEX' and owner='&owner' group by segment_name; 14.查看某表/索引的大小 表 SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments where segment_name=upper('&table_name'); 索引 SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments where segment_name=upper('&index_name');15、确定可用空间 select tablespace_name,sum(blocks),sum(bytes) from sys.dba_free_space group by tablespace_name;16、程序中报错:maxinum cursor exceed! <1> 查看当前的open cursor参数 sql> show parameter open_cursors <2> 假如确实很小,应该调整数据库初始化文件 加如一项 open_cursors=200 <3> 假如很大,则 select sid,sql_text,count(*) from v$open_cursor group by sid,sql_text having count(*) > 200 其中200是随便写一个比较大的值。查询得到打开太多的cursor.17、查看数据库的版本信息 SQL> select * from v$version; 包含版本信息,核心版本信息,位数信息(32位或64位)等 至于位数信息,在linux/unix平台上,可以通过file查看,如 file $ORACLE_HOME/bin/oracle18. 查看最大会话数 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 DATABASE20. unix 下调整数据库的时间 su -root date -u 0801000021.P4电脑的安裝方法 将SYMCJIT.DLL改为SYSMCJIT.OLD22. 如何查询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 DBASTUDIO26.LINUX下查询磁盘竞争状况命令? Sar -d27.LINUX下查询磁盘CPU竞争状况命令? sar -r28. 查询表空间信息? 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=-20038. 怎样查看哪些用户拥有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
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 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:/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 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.查询当前正在执行的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_address82.怎么样给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 index83.如何移动数据文件 <1>、关闭数据库,利用os拷贝 a.shutdown immediate关闭数据库 b.在os下拷贝数据文件到新的地点 c.Startup mount 启动到mount下 d.Alter database rename datafile '老文件' to '新文件'; e.Alter database open; 打开数据库 <2>、利用Rman联机操作 RMAN> sql "alter database datafile ''file name'' offline"; RMAN> run {
2> copy datafile 'old file location' 3> to 'new file location'; 4> switch datafile ' old file location' 5> to datafilecopy ' new file location'; 6> } RMAN> sql "alter database datafile ''file name'' online"; 说明:利用OS拷贝也可以联机操作,不关闭数据库,与rman的步骤一样,利用rman与利用os拷贝的原理一样,在rman中copy是拷贝数据文件,相当于OS的cp,而switch则相当于alter database rename,用来更新控制文件。84.如何治理联机日志组与成员 以下是常见操作,假如在OPA/RAC下注重线程号 增加一个日志文件组 Alter database add logfile [group n] '文件全名' size 10M; 在这个组上增加一个成员 Alter database add logfile member '文件全名' to group n; 在这个组上删除一个日志成员 Alter database drop logfile member '文件全名'; 删除整个日志组 Alter database drop logfile group n;85.怎么样计算REDO BLOCK的大小 [A]计算方法为(redo size + redo wastage) / redo blocks written + 16 具体见如下例子 SQL> select name ,value from v$sysstat where name like '%redo%'; NAME VALUE -------------------------------------------------- redo synch writes 2 redo synch time 0 redo entries 76 redo size 19412 redo buffer allocation retries 0 redo wastage 5884 redo writer latching time 0 redo writes 22 redo blocks written 51 redo write time 0 redo log space requests 0 redo log space wait time 0 redo log switch interrupts 0 redo ordering marks 0 SQL> select (19412+5884)/51 + 16 '"Redo black(byte)" from dual; Redo black(byte) ------------------ 51286.假如发现表中有坏块,如何检索其它未坏的数据 [A]首先需要找到坏块的ID(可以运行dbverify实现),假设为,假定文件编码为。运行下面的查询查找段名: SELECT segment_name,segment_type,extent_id,block_id, blocks from dba_extents t where file_id = AND between block_id and (block_id + blocks - 1) 一旦找到坏段名称,若段是一个表,则最好建立一个临时表,存放好的数据。若段是索引,则删除它,再重建。 create table good_table as select from bad_table where rowid not in (select rowid from bad_table where substr(rowid,10,6) = ) 在这里要注重8以前的受限ROWID与现在ROWID的差别。 还可以使用诊断事件10231 SQL> ALTER SYSTEM SET EVENTS '10231 trace name context forever,level 10'; 创建一个临时表good_table的表中除坏块的数据都检索出来 SQL>CREATE TABLE good_table as select * from bad_table; 最后关闭诊断事件 SQL> ALTER SYSTEM SET EVENTS '10231 trace name context off '; 关于ROWID的结构,还可以参考dbms_rowid.rowid_create函数87.怎么样备份控制文件 在线备份为一个二进制的文件 alter database backup controlfile to '$BACKUP_DEPT/controlfile.000' [reuse]; 备份为文本文件方式 alter database backup controlfile to trace [resetlogsnoresetlogs]; 88.控制文件损坏如何恢复 <1>、假如是损坏单个控制文件 只需要关闭数据库,拷贝一个好的数据文件覆盖掉坏的数据文件即可 或者是修改init.ora文件的相关部分 <2>、假如是损失全部控制文件,则需要创建控制文件或从备份恢复 创建控制文件的脚本可以通过alter database backup controlfile to trace获取。89.怎么样热备份一个表空间 <1>Alter tablespace 名称 begin backup; host cp 这个表空间的数据文件 目的地; Alter tablespace 名称 end backup; 假如是备份多个表空间或整个数据库,只需要一个一个表空间的操作下来就可以了。90.怎么快速得到整个数据库的热备脚本 <1>可以写一段类似的脚本 SQL>set serveroutput on begin dbms_output.enable(10000); for bk_ts in (select distinct t.ts#,t.name from v$tablespace t,v$datafile d where t.ts#=d.ts#) loop
dbms_output.put_line('--'bk_ts.name); dbms_output.put_line('alter tablespace 'bk_ts.name' begin backup;'); for bk_file in (select file#,name from v$datafile where ts#=bk_ts.ts#) loop dbms_output.put_line('host cp 'bk_file.name' $BACKUP_DEPT/'); end loop; dbms_output.put_line('alter tablespace 'bk_ts.name' end backup;'); end loop; end; /91.丢失一个数据文件,但是没有备份,怎么样打开数据库 假如没有备份只能是删除这个数据文件了,会导致相应的数据丢失。 SQL>startup mount --ARCHIVELOG模式命令 SQL>Alter database datafile 'file name' offline; --NOARCHIVELOG模式命令 SQL>Alter database datafile 'file name' offline drop; SQLl>Alter database open; 注重:该数据文件不能是系统数据文件92.丢失一个数据文件,没有备份但是有该数据文件创建以来的归档怎么恢复 保证如下条件 a. 不能是系统数据文件 b. 不能丢失控制文件 假如满足以上条件,则 SQL>startup mount SQL>Alter database create datafile 'file name' as 'file name' size ... reuse; SQL>recover datafile n; -文件号 或者 SQL>recover datafile 'file name'; 或者 SQL>recover database; SQL>Alter database open;93.联机日志损坏如何恢复 <1>、假如是非当前日志而且归档,可以使用 Alter database clear logfile group n来创建一个新的日志文件 假如该日志还没有归档,则需要用 Alter database clear unarchived logfile group n <2>、假如是当前日志损坏,一般不能clear,则可能意味着丢失数据 假如有备份,可以采用备份进行不完全恢复 假如没有备份,可能只能用_allow_resetlogs_corruption=true来进行强制恢复了,但是,这样的方法是不建议的,最好在有Oracle support的指导下进行。94.怎么样创建RMAN恢复目录 首先,创建一个数据库用户,一般都是RMAN,并给予recovery_catalog_owner角色权限 sqlplus sys SQL> create user rman identified by rman; SQL> alter user rman default tablespace tools temporary tablespace temp; SQL> alter user rman quota unlimited on tools; SQL> grant connect, resource, recovery_catalog_owner to rman; SQL> exit; 然后,用这个用户登录,创建恢复目录 rman catalog rman/rman RMAN> create catalog tablespace tools; RMAN> exit; 最后,你可以在恢复目录注册目标数据库了 rman catalog rman/rman target backdba/backdba RMAN> register database;95.怎么样在恢复的时候移动数据文件,恢复到别的地点 给一个RMAN的例子 run { set until time 'Jul 01 1999 00:05:00'; allocate channel d1 type disk; set newname for datafile '/u04/oracle/prod/sys1prod.dbf' to '/u02/oracle/prod/sys1prod.dbf'; set newname for datafile '/u04/oracle/prod/usr1prod.dbf' to '/u02/oracle/prod/usr1prod.dbf'; set newname for datafile '/u04/oracle/prod/tmp1prod.dbf' to '/u02/oracle/prod/tmp1prod.dbf'; restore controlfile to '/u02/oracle/prod/ctl1prod.ora'; replicate controlfile from '/u02/oracle/prod/ctl1prod.ora'; restore database; sql "alter database mount"; switch datafile all; recover database; sql "alter database open resetlogs"; release channel d1; } 96.怎么从备份片(backuppiece)中恢复(restore)控制文件与数据文件 可以使用如下方法,在RMAN中恢复备份片的控制文件 restore controlfile from backuppiecefile; 假如是9i的自动备份,可以采用如下的方法 restore controlfile from autobackup; 但是,假如控制文件全部丢失,需要指定DBID,如SET DBID=? 自动备份控制文件的默认格式是%F,这个格式的形式为 c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII就是DBID
至于恢复(restore)数据文件,oracle 816开始有个包dbms_backup_restore 在 nomount 状态下就可以执行,可以读 815甚至之前的备份片,读出来的文件用于恢复 可以在SQLPLUS中运行,如下 SQL>startup nomount SQL> DECLARE 2 devtype varchar2(256); 3 done boolean; 4 BEGIN 5 devtype := dbms_backup_restore.deviceallocate('', params=>''); 6 dbms_backup_restore.restoresetdatafile; 7 dbms_backup_restore.restorecontrolfileto('E:/Oracle/oradata/penny/control01.ctl'); 8 dbms_backup_restore.restoreDataFileto(1,'E:/Oracle/oradata/penny/system01.dbf'); 9 dbms_backup_restore.restoreDataFileto(2,'E:/Oracle/oradata/penny/UNDOTBS01.DBF'); 10 dbms_backup_restore.restoreDataFileto(3,'E:/ORACLE/ORADATA/PENNY/USERS01.DBF'); 11 dbms_backup_restore.restorebackuppiece('D:/orabak/BACKUP_1_4_04F4IAJT.PENNY',done=>done); 12 END; 13 / PL/SQL 过程已成功完成。 SQL> alter database mount; [Q]Rman的format格式中的%s类似的东西代表什么意义 [A]可以参考如下 %c 备份片的拷贝数 %d 数据库名称 %D 位于该月中的第几天 (DD) %M 位于该年中的第几月 (MM) %F 一个基于DBID唯一的名称,这个格式的形式为c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII为该数据库的DBID,YYYYMMDD为日期,QQ是一个1-256的序列 %n 数据库名称,向右填补到最大八个字符 %u 一个八个字符的名称代表备份集与创建时间 %p 该备份集中的备份片号,从1开始到创建的文件数 %U 一个唯一的文件名,代表%u_%p_%c %s 备份集的号 %t 备份集时间戳 %T 年月日格式(YYYYMMDD)97.执行exec dbms_logmnr_d.build('Logminer.ora','file Directory'),提示下标超界,怎么办 完整错误信息如下, SQL> exec dbms_logmnr_d.build('Logminer.ora','file directory') BEGIN dbms_logmnr_d.build('Logminer.ora','file directory'); END; * ERROR 位于第 1 行: ORA-06532: 下标超出限制 ORA-06512: 在"SYS.DBMS_LOGMNR_D", line 793 ORA-06512: 在line 1 解决办法为: <1>.编辑位于"$ORACLE_HOME/rdbms/admin"目录下的文件"dbmslmd.sql" 改变行: TYPE col_desc_array IS VARRAY(513) OF col_description; 为 TYPE col_desc_array IS VARRAY(700) OF col_description; 并保存文件 <2>. 运行改变后的脚本 SQLPLUS> Connect internal SQLPLUS> @$ORACLE_HOME/rdbms/admin/dbmslmd.sql <3>.重新编译该包 SQLPLUS> alter package DBMS_LOGMNR_D compile body;98.执行execute dbms_logmnr.start_logmnr(DictFileName=>'DictFileName')提示ORA-01843:无效的月份,这个是什么原因 我们分析start_logmnr包 PROCEDURE start_logmnr( startScn IN NUMBER default 0 , endScn IN NUMBER default 0, startTime IN DATE default TO_DATE('01-jan-1988','DD-MON-YYYY'), endTime IN DATE default TO_DATE('01-jan-2988','DD-MON-YYYY'), DictFileName IN VARCHAR2 default '', Options IN BINARY_INTEGER default 0 ); 可以知道,假如TO_DATE('01-jan-1988','DD-MON-YYYY')失败,将导致以上错误 所以解决办法可以为 <1>、Alter session set NLS_LANGUAGE=American <2>、用类似如下的方法执行 execute dbms_logmnr.start_logmnr (DictFileName=> 'f:/temp2/TESTDICT.ora', starttime => TO_DATE( '01-01-1988','DD-MM-YYYY'), endTime=>TO_DATE('01-01-2988','DD-MM-YYYY'));