首页 行业资讯 宠物日常 宠物养护 宠物健康 宠物故事
您的当前位置:首页正文

我的oracle笔记四(DBA管理)

2022-09-10 来源:画鸵萌宠网
我的oracle笔记四(DBA管理)

Oracle需要启动OracleServiceORCL,OracleStartORCL,OracleTNSListener 任务

上至少要启动两个服务

startID和oracleserverID

据库都有一个系统标识符(SID),典型安装的数据库使用的系统标识符是ORCL

关闭数据库

>connect internal/oracle

own --正常关闭数据库

>shutdown immediate --立即关闭数据库

>shutdown abort --一种最直接的关闭数据库的方式,执行之后,重新启动需要花6-8小时

>startup --正常启动

于:startup nomount;

database mount;

database open;

>startup mount; --安装启动:用于改变数据库的归档或执行恢复状态

>startup nomount; --用于重建控制文件或重建数据库

>startup restrict; --约束启动,能启动数据库,但只答应具有一定特权的用户访问

望改变这种状态,连接成功后

system disable restricted session;

>startup force;当不能关闭数据库时,可采用强制启动数据库来完成数据库的关闭操作。

>startup pfile=d:\\orant\\database\\initorcl.ora --带初始化参数文件的启动

用户和密码

acle安裝完成后的初始口令?

al/oracle

nge_on_install

manager

iger

oem_temp

ACLE9IAS WEB CACHE的初始默认用户和密码?

strator/administrator

义自己的回滚段生效

orcl.ora中加入rollback_segments=(rb0,rb1,...)

0,rb1为自己定义的回滚段,可使这些回滚段在启动时生效

修改数据库的字符集

库服务器字符集

ops$中

props$ set value$='ZHS16CGB231280'

name ='NLS_CHARACTERSET'

新启动数据库,而不需要重新安装

版本可以通过alter database来修改字符集,但也只限于子集到超集,不建议修改props$表,将可能导致严重错误。

nomount;

atabase mount exclusive;

ystem enable restricted session;

ystem set job_queue_process=0;

atabase open;

atabase character set zhs16gbk;

how parameter NLS

据库字符集:

* FROM NLS_DATABASE_PARAMETERS;

* FROM V$NLS_PARAMETERS;

字符集环境select * from nls_instance_parameters,其来源于v$parameter,

户端的字符集的设置,可能是参数文件,环境变量或者是注册表

符集环境 select * from nls_session_parameters,其来源于v$nls_parameters,表示会话自己的设置,可能是会话的环境变量或

,假如会话没有非凡的设置,将与nls_instance_parameters一致。

的字符集要求与服务器一致,才能正确显示数据库的非Ascii字符。假如多个设置存在的时候,alter session>环境变量>注册表>参

要求一致,但是语言设置却可以不同,语言设置建议用英文。如字符集是zhs16gbk,则nls_lang可以是American_America.zhs16gb

时候用crontab发起的时候,由于执行的shell脚本的不同,导致很多的环境变量不同。经常看到插入到数据库中的汉字变成乱码。

ell脚本cai.sh如下内容。

ksh

ORACLE_BASE=/u01/oracle/app/oracle

ORACLE_HOME=${ORACLE_BASE}/prodUCt/9.2.0

ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data

LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATH

SHLIB_PATH=$ORACLE_HOME/lib32:$ORACLE_HOME/rdbms/lib32:/app/prepay/lib

acle/app/oracle/product/9.2.0/bin/sqlplus aicbs/aicbs@busi_cs <into okcai values('okcai是个大好人呀');

ab中定时天天20:19执行一次

* * /bin/sh /app/prepay/cai.sh >/dev/null 2>&1 &

看到数据库中数据变成了:

据库的字符集是

* FROM NLS_DATABASE_PARAMETERS

N.ZHS16GBK

常,必须保持客户端和数据库一致的字符集

如下即可

ksh

ORACLE_BASE=/u01/oracle/app/oracle

ORACLE_HOME=${ORACLE_BASE}/product/9.2.0

ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data

LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/rdbms/lib:$LD_LIBRARY_PATH

SHLIB_PATH=$ORACLE_HOME/lib32:$ORACLE_HOME/rdbms/lib32:/app/prepay/lib

面就是增加的

NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

acle/app/oracle/product/9.2.0/bin/sqlplus aicbs/aicbs@busi_cs <into okcai values('okcai是个大好人呀');

gr>show sga

锁的原因

程被死锁,可以按下面方式查询

$session或者v$locked_object找到此session

如有lockwait,查询v$lock,

* from v$lock where kaddr = 'C00000024AB87210'

有,根据sid

* from v$lock where sid = 438

看v$lock

> 0,表示已经得到此锁

t > 0 表示正在请求此锁

1和id2的值可以判定请求哪个锁的释放。

* from v$lock where id1=134132 and id2 = 31431

锁的状况的对象

V$LOCKED_OBJECT, V$SESSION, V$SQLAREA, V$PROCESS ;

的表的方法:

S.SID SESSION_ID, S.USERNAME,

LMODE, 0, 'None', 1, 'Null', 2, 'Row-S (SS)', 3, 'Row-X (SX)', 4, 'Share', 5, 'S/Row-X (SSX)', 6, 'Exclusive', TO_C

REQUEST, 0, 'None', 1, 'Null', 2, 'Row-S (SS)', 3, 'Row-X (SX)', 4, 'Share', 5, 'S/Row-X (SSX)', 6, 'Exclusive', TO_CHA

TED,

R'.'O.OBJECT_NAME' ('O.OBJECT_TYPE')', S.TYPE LOCK_TYPE, L.ID1 LOCK_ID1, L.ID2 LOCK_ID2

LOCK L, SYS.DBA_OBJECTS O, V$SESSION S

.SID = S.SID AND L.ID1 = O.OBJECT_ID ;

查得数据库的SID ?

name from v$database;

直接查看 init.ora文件

理回滚段:

务的恢复信息

滚段

public rollback segment SEG_NAME tabelspace TABLESPACE_NAME;

rollback segment SEG_NAME online;

滚段

变为offline状态

用回滚段

t transaction use rollback segment SEG_NAME;

算一个表占用的空间的大小

owner,table_name,

S,

AAA/1024/1024 \"Size M\

LOCKS,

ALYZED

a_tables

able_name='XXX';

AA is the value of db_block_size ;

the table name you want to check

在表空间中的存储情况

segment_name,sum(bytes),count(*) ext_quan from dba_extents where

pace_name='&tablespace_name' and segment_type='TABLE' group by tablespace_name,segment_name;

引在表空间中的存储情况

segment_name,count(*) from dba_extents where segment_type='INDEX' and owner='&owner'

by segment_name;

某表/索引的大小

lect sum(bytes)/(1024*1024) as \"size(M)\" from user_segments

segment_name=upper('&table_name');

lect sum(bytes)/(1024*1024) as \"size(M)\" from user_segments

segment_name=upper('&index_name');

定可用空间

tablespace_name,sum(blocks),sum(bytes) from sys.dba_free_space group by tablespace_name;

序中报错:maxinum cursor exceed!

看当前的open cursor参数

how parameter open_cursors

如确实很小,应该调整数据库初始化文件

项 open_cursors=200

如很大,则

sid,sql_text,count(*) from v$open_cursor

y sid,sql_text

count(*) > 200

是随便写一个比较大的值。查询得到打开太多的cursor.

看数据库的版本信息

lect * from v$version;

本信息,核心版本信息,位数信息(32位或64位)等

数信息,在Linux/unix平台上,可以通过file查看,如

RACLE_HOME/bin/oracle

看最大会话数

* FROM V$PARAMETER WHERE NAME LIKE 'proc%';

ow parameter processes

YPE VALUE

-----------------------------------------

rocesses integer 1

er_processes integer 1

ue_processes integer 4

hive_max_processes integer 1

es integer 200

00个用户。

* from v$license;

sions_highwater纪录曾经到达的最大会话数

rchivelog的方式运行oracle。

a

hive_start = true

DATABASE

x 下调整数据库的时间

t

08010000

脑的安裝方法

IT.DLL改为SYSMCJIT.OLD

何查询SERVER是不是OPS?

* FROM V$OPTION;

ALLEL SERVER=TRUE则有OPS能

询每个用户的权限

* FROM DBA_SYS_PRIVS;

/索引移动表空间

ABLE TABLE_NAME MOVE TABLESPACE_NAME;

NDEX INDEX_NAME REBUILD TABLESPACE TABLESPACE_NAME;

NUX,UNIX下启动DBA STUDIO?

DBASTUDIO

X下查询磁盘竞争状况命令?

X下查询磁盘CPU竞争状况命令?

询表空间信息?

* FROM DBA_DATA_FILES;

各个表空间占用磁盘情况:

l tablespace format a20

elect

_id 文件ID号,

espace_name 表空间名,

s 字节数,

es-sum(nvl(a.bytes,0))) 已使用,

l(a.bytes,0)) 剩余空间,

l(a.bytes,0))/(b.bytes)*100 剩余百分比

ba_free_space a,dba_data_files b

a.file_id=b.file_id

by b.tablespace_name,b.file_id,b.bytes

by b.file_id

把ORACLE设置为MTS或专用模式?

chers=\"(PROTOCOL=TCP) (SERVICE=SIDXDB)\"

是MTS,注释就是专用模式,SID是指你的实例名。

何才能得知系统当前的SCN号 ?

max(ktuxescnw * power(2, 32) + ktuxescnb) from x$ktuxe;

改oracel数据库的默认日期

ession set nls_date_format='yyyymmddhh24miss';

nit.ora中加上一行

e_format='yyyymmddhh24miss'

小表放入keep池中

able xxx storage(buffer_pool keep);

何检查是否安装了某个patch?

hat oraInventory

何修改oracle数据库的用户连接数?

tSID.ora,将process加大,重启数据库.

何创建SPFILE?

nnect / as sysdba

lect * from v$version;

eate pfile from spfile;

EATE SPFILE FROM PFILE='E:\\ora9i\\admin\\eygle\\pfile\\init.ora';

创建。

EATE SPFILE='E:\\ora9i\\database\\SPFILEEYGLE.ORA' FROM PFILE='E:\\ora9i\\admin\\eygle\\pfile\\init.ora';

创建。

核参数的应用

这个设置并不决定究竟Oracle数据库或者操作系统使用多少物理内存,只决定了最多可以使用的内存数目。这个设置也不影响操作系

法:0.5*物理内存

et shmsys:shminfo_shmmax=10485760

共享内存的最小大小。

法:一般都设置成为1。

et shmsys:shminfo_shmmin=1:

系统中共享内存段的最大个数。

et shmsys:shminfo_shmmni=100

每个用户进程可以使用的最多的共享内存段的数目。

et shmsys:shminfo_shmseg=20:

系统中semaphore identifierer的最大个数。

法:把这个变量的值设置为这个系统上的所有Oracle的实例的init.ora中的最大的那个processes的那个值加10。

et semsys:seminfo_semmni=100

系统中emaphores的最大个数。

法:这个值可以通过以下方式计算得到:各个Oracle实例的initSID.ora里边的processes的值的总和(除去最大的Processes参数

es×2+10×Oracle实例的个数。

et semsys:seminfo_semmns=200

一个set中semaphore的最大个数。

法:设置成为10+所有Oracle实例的InitSID.ora中最大的Processes的值。

et semsys:seminfo_semmsl=-200

样查看哪些用户拥有SYSDBA、SYSOPER权限?

n sys/change_on_install

ect * from V_$PWFILE_USERS;

何查看数据文件放置的路径 ?

e_name format a50

lect tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_files order by file_id;

何查看现有回滚段及其状态 ?

l segment format a30

LECT SEGMENT_NAME,OWNER,TABLESPACE_NAME,SEGMENT_ID,FILE_ID,STATUS FROM DBA_ROLLBACK_SEGS

cle常用系统文件有哪些?

下视图显示这些文件信息:v$database,v$datafile,v$logfile v$controlfile v$parameter;

数据库实例

ECT * FROM V$INSTANCE;

样估算SQL执行的I/O数 ?

AUTOTRACE ON ;

LECT * FROM TABLE;

ECT * FROM v$filestat ;

看IO数

样扩大REDO LOG的大小?

个临时的redolog组,然后切换日志,删除以前的日志,建立新的日志。

询做比较大的排序的进程?

b.tablespace, b.segfile#, b.segblk#, b.blocks, a.sid, a.serial#,

name, a.osuser, a.status

$session a,v$sort_usage b

a.saddr = b.session_addr

BY b.tablespace, b.segfile#, b.segblk#, b.blocks ;

查询做比较大的排序的进程的SQL语句

/*+ ORDERED */ sql_text from v$sqltext a

a.hash_value = (

sql_hash_value from v$session b

b.sid = &sid and b.serial# = &serial)

by piece asc ;

-01555 SNAPSHOT TOO OLD的解决办法

NEXTENTS的值,增加区的大小,设置一个高的OPTIMAL值。

执行大的事务,报此错误,说明oracle给此事务随机分配的回滚段太小了,这时可以为它指定一个足够大的回滚段,以确保这个事务

nsaction use rollback segment roll_abc;

from table_name where ...

oll_abc被指定给这个delete事务,commit命令则在事务结束之后取消了回滚段的指定.

务要求的回滚段空间不够,表现为表空间用满(ORA-01560错误),回滚段扩展到达参数 MAXEXTENTS的值(ORA-01628)的解决办法

段表空间添加文件或使已有的文件变大;增加MAXEXTENTS的值。

控事例的等待

event,sum(decode(wait_Time,0,0,1)) \"Prev\

code(wait_Time,0,1,0)) \"Curr\

$session_Wait

by event order by 4;

滚段的争用情况

name, waits, gets, waits/gets \"Ratio\"

$rollstat C, v$rollname D

C.usn = D.usn;

表空间的 I/O 比例

B.tablespace_name name,B.file_name \"file\

lkrd pbr,A.phywrts pyw, A.phyblkwrt pbw

$filestat A, dba_data_files B

A.file# = B.file_id

by B.tablespace_name;

控文件系统的 I/O 比例

substr(C.file#,1,2) \"#\

us, C.bytes, D.phyrds, D.phywrts

$datafile C, v$filestat D

C.file# = D.file#;

控 SGA 的命中率

a.value + b.value \"logical_reads\

100 * ((a.value+b.value)-c.value) / (a.value+b.value)) \"BUFFER HIT RATIO\"

$sysstat a, v$sysstat b, v$sysstat c

a.statistic# = 38 and b.statistic# = 39

statistic# = 40;

控 SGA 中字典缓冲区的命中率

parameter, gets,Getmisses , getmisses/(gets+getmisses)*100 \"miss ratio\

m(getmisses)/ (sum(gets)+sum(getmisses))))*100 \"Hit ratio\"

$rowcache

gets+getmisses <>0

by parameter, gets, getmisses;

控 SGA 中共享缓存区的命中率,应该小于1%

sum(pins) \"Total Pins\

loads)/sum(pins) *100 libcache

$librarycache;

sum(pinhits-reloads)/sum(pins) \"hit radio\

$librarycache;

示所有数据库对象的类别和大小

count(name) num_instances ,type ,sum(source_size) source_size ,

rsed_size) parsed_size ,sum(code_size) code_size ,sum(error_size) error_size,

urce_size) +sum(parsed_size) +sum(code_size) +sum(error_size) size_required

ba_object_size

by type order by 2;

控 SGA 中重做日志缓存区的命中率,应该小于1%

name, gets, misses, immediate_gets, immediate_misses,

(gets,0,0,misses/gets*100) ratio1,

(immediate_gets+immediate_misses,0,0,

ate_misses/(immediate_gets+immediate_misses)*100) ratio2

$latch WHERE name IN ('redo allocation', 'redo copy');

控内存和硬盘的排序比率,最好使它小于 .10,增加 sort_area_size

name, value FROM v$sysstat WHERE name IN ('sorts (memory)', 'sorts (disk)');

控当前数据库谁在运行什么SQL语句?

osuser, username, sql_text from v$session a, v$sqltext b

a.sql_address =b.address order by address, piece;

控字典缓冲区?

(SUM(PINS - RELOADS)) / SUM(PINS) \"LIB CACHE\" FROM V$LIBRARYCACHE;

(SUM(GETS - GETMISSES - USAGE - FIXED)) / SUM(GETS) \"ROW CACHE\" FROM V$ROWCACHE;

SUM(PINS) \"EXECUTIONS\

以前者,此比率小于1%,接近0%为好。

SUM(GETS) \"DICTIONARY GETS\

$ROWCACHE

控 MTS

busy/(busy+idle) \"shared servers busy\" from v$dispatcher;

于0.5时,参数需加大

sum(wait)/sum(totalq) \"dispatcher waits\" from v$queue where type='dispatcher';

count(*) from v$dispatcher;

servers_highwater from v$mts;

s_highwater接近mts_max_servers时,参数需加大

看碎片程度高的表?

segment_name table_name , COUNT(*) extents

ba_segments WHERE owner NOT IN ('SYS', 'SYSTEM') GROUP BY segment_name

COUNT(*) = (SELECT MAX( COUNT(*) ) FROM dba_segments GROUP BY segment_name);

何知道使用CPU多的用户session?

pu used by this session

a.sid,spid,status,substr(a.program,1,40) prog,a.terminal,osuser,value/60/100 value

$session a,v$process b,v$sesstat c

c.statistic#=11 and c.sid=a.sid and a.paddr=b.addr order by value desc;

检查操作系统是否存在IO的问题

工具有sar,这是一个比较通用的工具。

2 10

秒检察一次,共执行20次,当然这些都由你决定了。

回:

hpn2 B.11.00 U 9000/800 08/05/03

32 %usr %sys %wio %idle

34 80 9 12 0

36 78 11 11 0

38 78 9 13 1

40 81 10 9 1

42 75 10 14 0

44 76 8 15 0

46 80 9 10 1

48 78 11 11 0

50 79 10 10 0

52 81 10 9 0

e 79 10 11 0

usr指的是用户进程使用的cpu资源的百分比,

的是系统资源使用cpu资源的百分比,

的是等待io完成的百分比,这是值得我们观注的一项,

空闲的百分比。假如wio列的值很大,如在35%以上,说明你的系统的IO存在瓶颈,你的CPU花费了很大的时间去等待IO的完成。

小说明系统CPU很忙。像我的这个示例,可以看到wio平均值为11说明io没什么非凡的问题,而我的idle值为零,说明我的cpu已

一下内存。

工具便是vmstat,对于hp-unix来说可以用glance,Aix来说可以用topas,当你发现vmstat中pi列非零,memory中的free列的值

s中内存的利用率多于80%时,这时说明你的内存方面应该调节一下了,方法大体有以下几项。

Oracle使用的内存不要超过系统内存的1/2,一般保在系统内存的40%为益。

统增加内存

你的连接非凡多,可以使用MTS的方式

补丁,防止内存漏洞。

找前十条性能差的sql.

* FROM

PARSING_USER_ID

IONS,

D_TYPE,

EADS,

xt

$sqlarea

BY disk_reads DESC

ROWNUM<10 ;

看占io较大的正在运行的session

se.sid,

ial#,

D,

rname,

tus,

minal,

gram,

ULE,

_address,

nt,

ext,

sical_reads,

ck_changes

$session se,

ion_wait st,

_io si,

ess pr

t.sid=se.sid

.sid=si.sid

.PADDR=pr.ADDR

.sid>6

.wait_time=0

.event NOT LIKE '%SQL%'

Y physical_reads DESC

出的结果的几点说明:

是按每个正在等待的session已经发生的物理读排的序,因为它与实际的IO相关。

可以看一下这些等待的进程都在忙什么,语句是否合理?

sql_address from v$session where sid=;

* from v$sqltext where address=;

上两个语句便可以得到这个session的语句。

用alter system kill session 'sid,serial#';把这个session杀掉。

观注一下event这列,这是我们调优的要害一列,下面对常出现的event做以简要的说明:

fer busy waits,free buffer waits这两个参数所标识是dbwr是否够用的问题,与IO很大相关的,当v$session_wait中的free

或没有的时侯,说明你的系统的dbwr进程决对够用,不用调整;free buffer wait的条目很多,你的系统感觉起来一定很慢,这时说

了,它产生的wio已经成为你的数据库性能的瓶颈,这时的解决办法如下:

写进程,同时要调整db_block_lru_latches参数

修改或添加如下两个参数

ter_processes=4

ck_lru_latches=8

步IO,IBM这方面简单得多,hp则麻烦一些,可以与Hp工程师联系。

file sequential read,指的是顺序读,即全表扫描,这也是我们应该尽量减少的部分,解决方法就是使用索引、sql调优,同时可

tiblock_read_count这个参数。

file scattered read,这个参数指的是通过索引来读取,同样可以通过增加db_file_multiblock_read_count这个参数来提高性能。

ch free,与栓相关的了,需要专门调节。

他参数可以不非凡观注。

件说明

器日志文件

为例

E_HOME/NETWORK/LOG/LISTENER.LOG

听器参数文件

为例

E_HOME/NETWORK/ADMIN/LISTENER.ORA

S 连接文件

为例

E_HOME/NETWORK/ADMIN/TNSNAMES.ORA

l*Net 环境文件

为例

E_HOME/NETWORK/ADMIN/SQLNET.ORA

告日志文件

为例

E_HOME/ADMIN/SID/BDUMP/SIDALRT.LOG

本结构

为例

E_HOME/RDBMS/ADMIN/STANDARD.SQL

立数据字典视图

为例

E_HOME/RDBMS/ADMIN/CATALOG.SQL

立审计用数据字典视图

为例

E_HOME/RDBMS/ADMIN/CATAUDIT.SQL

立快照用数据字典视图

为例

E_HOME/RDBMS/ADMIN/CATSNAP.SQL

cle 安全与审计

ys_privs,user_tab_privs;

n_per_user 每个用户可同时进行几个会话

r_session 每个用户可用多少个(cpu的)百分之一秒

r_call 语法分析、执行、取数可用多少个百分之一秒

t_time 用户连接数据库的时间(分钟)

ime 用户不调用数据库的时间(分钟)

l_reads_per_session 整个会话过程中用户访问oracle的块数

l_reads_per_call 一次调用用户访问oracle的块数

e_SGA 一个用户进程所用SGA的内存数量

ite_limit 复合限制数

_login_attempts 连续多次注册失败引起一个帐户死锁

rd_life_time 一个口令在其终止前可用的天数

rd_reuse_time 一个口令在其n天才能重新使用

rd_reuse_max 一个口令在重新使用之前必须改变多少次

rd_lock_time 一个口令帐户被锁住的天数

理初始化文件

arameters

改的项目有 v$parameter

_pool_size 分配给共享的字节数

ck_segments 回滚段的个数

ns 会话个数

ses 进程个数

理控制文件

件保存文件有关数据库创建时间、数据库名以及数据库运行时使用的所有文件位置和名称。

制文件,在initorcl.ora中,找到control_file项,增加一项即可

制文件,在initorcl.ora中去掉,然后删除物理文件

的控制文件

controlfile [reuse] [set] database 数据库名

e [group 整数] 文件名 [,[group 整数] 文件名],...

有的数据库,可以间接地通过

database backup controlfile to trace命令生成控制文件,即可在\\orant\\rmb73\race

a00289.trc文件,其内容为文本

志治理

立日志组

lect * from v$logfile;

ter database add logfile group 3

rant\\database\\log1_g3.ora'

ant\\database\\log2_g3.ora') size 100k;

lect * from v$logfile;

ter database add logfile group 4

k3/log4a.rdo','/disk4/log4b.rdo') size 1m;

除日志组

database drop logfile group 1;

物理文件并没有被删除掉

少需要2个日志组,假如只有2个,就不能删除

除正活动的日志组

工归档

ter system 的archive log 子句来实现

e log [thread 整数]

整数][change 整数][current][group 整数]

le '文件名'][next][all][start][to '位置']

制日志切换

ter system switch logfile;

制checkpoints

lter system checkpoint;

ding online redo log members

er database add logfile member

3/log1b.rdo' to group 1,

4/log2b.rdo' to group 2;

anges the name of the online redo logfile

ter database rename file 'c:/oracle/oradata/oradb/redo01.log'

/oracle/oradata/redo01.log';

op online redo log members

ter database drop logfile member 'c:/oracle/oradata/redo01.log';

earing online redo log files

ter database clear [unarchived] logfile 'c:/oracle/log2a.rdo';

sing logminer analyzing redo logfiles

he init.ora specify utl_file_dir = ' '

execute dbms_logmnr_d.build('oradb.ora','c:\\oracle\\oradb\\log');

execute dbms_logmnr_add_logfile('c:\\oracle\\oradata\\oradb\\redo01.log',

bms_logmnr.new);

execute dbms_logmnr.add_logfile('c:\\oracle\\oradata\\oradb\\redo02.log',

bms_logmnr.addfile);

execute dbms_logmnr.start_logmnr(dictfilename=>'c:\\oracle\\oradb\\log\\oradb.ora');

select * from v$logmnr_contents(v$logmnr_dictionary,v$logmnr_parameters

$logmnr_logs);

> execute dbms_logmnr.end_logmnr;

控制

system ...

system enable restricted session; 只答应具有restricted系统特权的用户登录

system flush shared_pool 清除共享池

system checkpoint 执行一 个检查点

system set license_max_session=64,license_session_warning=54 会话限制为64,会话的警界为54

system set license_max_session=0 会话数为无限制

system set license_max_users=300 用户限制为300个

system switch logfile 强制执行日志转换

控制

session

session set sql_trace=true 当前会话具有sql跟踪功能

session set NLS_language=French 出错信息设为法语

session set NLS_date_format='YYYY MM DD HH24:MI:SS';缺省日期格式

session set optimizier_goal=first_row改变优化方法为基于开销方法,具有快速响应速度

student@teach set sold=sold+1 where sno='98010';

;

session close database link teach; 关闭远程链路

锁机制

锁:保护表数据,在多个用户并行存取数据时候,保证数据的完整性。

作又在两个级别获取数据封锁:指定记录封锁和表封锁

可以有下列方式:行共享(RS),行排他(RX),共享封锁(S),共享行排他(SPX)和排他

)

表封锁(RS),答应其他事务并行查询、插入,修改和删除及再行封锁

...from 表名 ... for update of ...;

able 表名 in row share mode;

表封锁(RX) 对该行有独占权利

into 表名 ...;

表名 ...;

from 表名 ...;

able 表名 in row exclusive mode;

行查询、插入、删除或封锁其他行,但禁止其他事务使用下列命令进行并发封锁:

able 表名 in share mode;

able 表名 in share exclusive mode;

able 表名 in exclusive mode;

封锁(S)

able 表名 in share mode;

他事务可在该表上做查询和再实现共享表操作,但不能修改该表,同时也不能做如下封锁:

able 表名 in share row exclusive mode;

able 表名 in exclusive mode;

able 表名 in row exclusive mode;

他表封锁(SRX)

able 表名 in share row exclusive mode;

封锁(SRX)

able 表名 in exclusive mode;

置事务

ansaction [read only][read write][use rollback segment 回滚段名]

希望用aimtzmcc用户连接数据库,访问aicbs用户的表,不在表名前缀\"aicbs.\",可以在建立数据库连接后发下面的命令

session set current_schema = aicbs;

空间治理

建表空间

eate tablespace tablespace_name datafile 'c:\\oracle\\oradata\\file1.dbf' size 100m,

c:\\oracle\\oradata\\file2.dbf' size 100m minimum extent 550k [logging/nologging]

fault storage (initial 500k next 500k maxextents 500 pctinccease 0)

nline/offline] [permanent/temporary] [extent_management_clause]

cally managed tablespace

eate tablespace user_data datafile 'c:\\oracle\\oradata\data01.dbf'

ze 500m extent management local uniform size 10m;

mporary tablespace

eate temporary tablespace temp tempfile 'c:\\oracle\\oradata\emp01.dbf'

ze 500m extent management local uniform size 10m;

ange the storage setting

ter tablespace app_data minimum extent 2m;

ter tablespace app_data default storage(initial 2m next 2m maxextents 999);

king tablespace offline or online

ter tablespace app_data offline;

ter tablespace app_data online;

ad_only tablespace

ter tablespace app_data read onlywrite;

oping tablespace

op tablespace app_data including contents;

ableing automatic extension of data files

ter tablespace app_data add datafile 'c:\\oracle\\oradata\\app_data01.dbf' size 200m

toextend on next 10m maxsize 500m;

ange the size fo data files manually

ter database datafile 'c:\\oracle\\oradata\\app_data.dbf' resize 200m;

oving data files: alter tablespace

ter tablespace app_data rename datafile 'c:\\oracle\\oradata\\app_data.dbf'

'c:\\oracle\\app_data.dbf';

oving data files:alter database

ter database rename file 'c:\\oracle\\oradata\\app_data.dbf'

'c:\\oracle\\app_data.dbf';

KUP and RECOVERY

sga,v$instance,v$process,v$bgprocess,v$database,v$datafile,v$sgastat

an need set dbwr_IO_slaves or backup_tape_IO_slaves and large_pool_size

nitoring Parallel Rollback

start_servers , v$fast_start_transactions

form a closed database backup (noarchivelog)

n immediate

s /backup/

tore to a different location

system/manager as sysdba

mount

atabase rename file '/disk1/../user.dbf' to '/disk2/../user.dbf';

atabase open;

over syntax

er a mounted database

database;

datafile '/disk1/data/df2.dbf';

atabase recover database;

er an opened database

tablespace user_data;

r datafile 2;

atabase recover datafile 2;

to apply redo log files automatically

orecovery on

automatic datafile 4;

plete recovery:

d 1(mounted databae)

\\backup\dbf c:\\oradata\dbf

mount

datafile 'c:\\oradata\dbf;

atabase open;

d 2(opened database,initially opened,not system or rollback datafile)

\\backup\dbf c:\\oradata\dbf (alter tablespace offline)

datafile 'c:\\oradata\dbf' or

tablespace user_data;

atabase datafile 'c:\\oradata\dbf' online or

ablespace user_data online;

d 3(opened database,initially closed not system or rollback datafile)

mount

atabase datafile 'c:\\oradata\dbf' offline;

atabase open

\\backup\dbf d:\\oradata\dbf

atabase rename file 'c:\\oradata\dbf' to 'd:\\oradata\dbf'

datafile 'e:\\oradata\dbf' or recover tablespace user_data;

ablespace user_data online;

d 4(loss of data file with no backup and have all archive log)

ablespace user_data offline immediate;

atabase create datafile 'd:\\oradata\dbf' as 'c:\\oradata\dbf''

tablespace user_data;

ablespace user_data online

form an open database backup

ablespace user_data begin backup;

les /backup/

atabase datafile '/c:/../data.dbf' end backup;

ystem switch logfile;

ckup a control file

atabase backup controlfile to 'control1.bkp';

atabase backup controlfile to trace;

covery (noarchivelog mode)

n abort

s

covery of file in backup mode

atabase datafile 2 end backup;

earing redo log file

atabase clear unarchived logfile group 1;

atabase clear unarchived logfile group 1 unrecoverable datafile;

do log recovery

atabase add logfile group 3 'c:\\oradata\\redo03.log' size 1000k;

atabase drop logfile group 1;

atabase open;

c:\\oradata\\redo02.log' c:\\oradata\\redo01.log

atabase clear logfile 'c:\\oradata\\log01.log';

ging password security and resources

trolling account lock and password

ter user juncky identified by oracle account unlock;

r_provided password function

nction_name(userid in varchar2(30),password in varchar2(30),

sword in varchar2(30)) return boolean

ate a profile : password setting

eate profile grace_5 limit failed_login_attempts 3

ssword_lock_time unlimited password_life_time 30

sword_reuse_time 30 password_verify_function verify_function

assword_grace_time 5;

ering a profile

ter profile default failed_login_attempts 3

ssword_life_time 60 password_grace_time 10;

p a profile

op profile grace_5 [cascade];

ate a profile : resource limit

eate profile developer_prof limit sessions_per_user 2

u_per_session 10000 idle_time 60 connect_time 480;

ew => resource_cost : alter resource cost

rs,dba_profiles

able resource limits

ter system set resource_limit=true;

ging privileges

tem privileges: view => system_privilege_map ,dba_sys_privs,session_privs

nt system privilege

ant create session,create table to managers;

ant create session to scott with admin option;

min option can grant or revoke privilege from any user or role;

dba and sysoper privileges:

: startup,shutdown,alter database openmount,alter database backup controlfile,

ablespace begin/end backup,recover database

atabase archivelog,restricted session

sysoper privileges with admin option,create database,recover database until

sword file members: view:=> v$pwfile_users

dictionary_Accessibility =true restriction access to view or tables in other schema

oke system privilege

voke create table from karen;

voke create session from scott;

nt object privilege

ant execute on dbms_pipe to public;

ant update(first_name,salary) on employee to karen with grant option;

play object privilege : view => dba_tab_privs, dba_col_privs

oke object privilege

voke execute on dbms_pipe from scott [cascade constraints];

dit record view :=> sys.aud$

rotecting the audit trail

dit delete on sys.aud$ by access;

atement auditing

dit user;

ivilege auditing

dit select any table by summit by access;

hema object auditing

dit lock on summit.employee by access whenever successful;

ew audit option : view=> all_def_audit_opts,dba_stmt_audit_opts,dba_priv_audit_opts,dba_obj_audit_opts

ew audit result: view=> dba_audit_trail,dba_audit_exists,dba_audit_object,dba_audit_session,dba_audit_statement

ger role

ate roles

eate role sales_clerk;

eate role hr_clerk identified by bonus;

eate role hr_manager identified externally;

ify role

lter role sales_clerk identified by commission;

ter role hr_clerk identified externally;

ter role hr_manager not identified;

igning roles

ant sales_clerk to scott;

ant hr_clerk to hr_manager;

ant hr_manager to scott with admin option;

ablish default role

ter user scott default role hr_clerk,sales_clerk;

ter user scott default role all;

ter user scott default role all except hr_clerk;

ter user scott default role none;

ble and disable roles

t role hr_clerk;

t role sales_clerk identified by commission;

t role all except sales_clerk;

t role none;

ove role from user

voke sales_clerk from scott;

voke hr_manager from public;

ove role

op role hr_manager;

play role information

>dba_roles,dba_role_privs,role_role_privs,dba_sys_privs,role_sys_privs,role_tab_privs,session_roles

当前正在执行的job的情况

对于需要执行的job查询执行情况,比如正在执行那条语句,或者想把job停下来等。一般不知道怎么查询到

行的session的sid.

* from dba_jobs_running

行比较慢,加

/*+ rule */* from dba_jobs_running

先得到job号,从user_jobs或者dba_jobs

* from user_jobs where upper(what) like '%MYPROGRAM%'

据job号查询sid号

* from v$lock where id2 = 3361910 and type ='JQ'

查询到sid了

询当前的执行什么语句

sql_text from v$sqlarea a,v$lock b,v$session c,user_jobs d

d.upper(what) like '%2004PRESENT%'

job = b.id2

type='JQ'

sid = c.sid

hash_value = c.sql_hash_value

address = c.sql_address

样给sqlplus安装帮助

LUS的帮助必须手工安装,shell脚本为$ORACLE_HOME/bin/helpins

之前,必须先设置SYSTEM_PASS环境变量,如:

v SYSTEM_PASS SYSTEM/MANAGER

ns

设置该环境变量,将在运行脚本的时候提示输入环境变量

除了shell脚本,还可以利用sql脚本安装,那就不用设置环境变量了,但是,我们必须以system登录。

us system/manager

/sqlplus/admin/help/helpbld.sql helpus.sql

后,你就可以象如下的方法使用帮助了

lp index

移动数据文件

闭数据库,利用os拷贝

own immediate关闭数据库

下拷贝数据文件到新的地点

up mount 启动到mount下

database rename datafile '老文件' to '新文件';

database open; 打开数据库

用Rman联机操作

ql \"alter database datafile ''file name'' offline\";

un {

y datafile 'old file location'

new file location';

ch datafile ' old file location'

atafilecopy ' new file location';

ql \"alter database datafile ''file name'' online\";

利用OS拷贝也可以联机操作,不关闭数据库,与rman的步骤一样,利用rman与利用os拷贝的原理一样,在rman中copy是拷贝数

,而switch则相当于alter database rename,用来更新控制文件。

治理联机日志组与成员

常见操作,假如在OPA/RAC下注重线程号

个日志文件组

atabase add logfile [group n] '文件全名' size 10M;

组上增加一个成员

atabase add logfile member '文件全名' to group n;

组上删除一个日志成员

atabase drop logfile member '文件全名';

个日志组

atabase drop logfile group n;

样计算REDO BLOCK的大小

方法为(redo size + redo wastage) / redo blocks written + 16

如下例子

lect name ,value from v$sysstat where name like '%redo%';

LUE

-------------------------------------------

nch writes 2

nch time 0

tries 76

ze 19412

ffer allocation retries 0

stage 5884

iter latching time 0

ites 22

ocks written 51

ite time 0

g space requests 0

g space wait time 0

g switch interrupts 0

dering marks 0

lect (19412+5884)/51 + 16 '\"Redo black(byte)\" from dual;

ack(byte)

-----------

发现表中有坏块,如何检索其它未坏的数据

需要找到坏块的ID(可以运行dbverify实现),假设为,假定文件编码为。运行下面的查询查找段名:

segment_name,segment_type,extent_id,block_id, blocks

a_extents t

=

ween block_id and (block_id + blocks - 1)

到坏段名称,若段是一个表,则最好建立一个临时表,存放好的数据。若段是索引,则删除它,再重建。

table good_table

from bad_table where rowid not in

rowid

d_table where substr(rowid,10,6) = )

要注重8以前的受限ROWID与现在ROWID的差别。

使用诊断事件10231

TER SYSTEM SET EVENTS '10231 trace name context forever,level 10';

个临时表good_table的表中除坏块的数据都检索出来

ATE TABLE good_table as select * from bad_table;

闭诊断事件

TER SYSTEM SET EVENTS '10231 trace name context off ';

ID的结构,还可以参考dbms_rowid.rowid_create函数

样备份控制文件

份为一个二进制的文件

atabase backup controlfile to '$BACKUP_DEPT/controlfile.000' [reuse];

文本文件方式

atabase backup controlfile to trace [resetlogsnoresetlogs];

文件损坏如何恢复

如是损坏单个控制文件

关闭数据库,拷贝一个好的数据文件覆盖掉坏的数据文件即可

修改init.ora文件的相关部分

如是损失全部控制文件,则需要创建控制文件或从备份恢复

制文件的脚本可以通过alter database backup controlfile to trace获取。

样热备份一个表空间

r tablespace 名称 begin backup;

这个表空间的数据文件 目的地;

ablespace 名称 end backup;

备份多个表空间或整个数据库,只需要一个一个表空间的操作下来就可以了。

快速得到整个数据库的热备脚本

写一段类似的脚本

serveroutput on

tput.enable(10000);

ts in (select distinct t.ts#,t.name from v$tablespace t,v$datafile d where t.ts#=d.ts#) loop

utput.put_line('--'bk_ts.name);

tput.put_line('alter tablespace 'bk_ts.name' begin backup;');

file in (select file#,name from v$datafile where ts#=bk_ts.ts#) loop

tput.put_line('host cp 'bk_file.name' $BACKUP_DEPT/');

p;

tput.put_line('alter tablespace 'bk_ts.name' end backup;');

p;

一个数据文件,但是没有备份,怎么样打开数据库

有备份只能是删除这个数据文件了,会导致相应的数据丢失。

rtup mount

VELOG模式命令

er database datafile 'file name' offline;

HIVELOG模式命令

er database datafile 'file name' offline drop;

ter database open;

该数据文件不能是系统数据文件

一个数据文件,没有备份但是有该数据文件创建以来的归档怎么恢复

下条件

是系统数据文件

丢失控制文件

足以上条件,则

rtup mount

er database create datafile 'file name' as 'file name' size ... reuse;

over datafile n; -文件号

over datafile 'file name';

over database;

er database open;

日志损坏如何恢复

如是非当前日志而且归档,可以使用

atabase clear logfile group n来创建一个新的日志文件

日志还没有归档,则需要用

atabase clear unarchived logfile group n

如是当前日志损坏,一般不能clear,则可能意味着丢失数据

备份,可以采用备份进行不完全恢复

有备份,可能只能用_allow_resetlogs_corruption=true来进行强制恢复了,但是,这样的方法是不建议的,最好在有Oracle supp

样创建RMAN恢复目录

创建一个数据库用户,一般都是RMAN,并给予recovery_catalog_owner角色权限

sys

eate user rman identified by rman;

ter user rman default tablespace tools temporary tablespace temp;

ter user rman quota unlimited on tools;

ant connect, resource, recovery_catalog_owner to rman;

it;

用这个用户登录,创建恢复目录

talog rman/rman

reate catalog tablespace tools;

xit;

你可以在恢复目录注册目标数据库了

talog rman/rman target backdba/backdba

egister database;

样在恢复的时候移动数据文件,恢复到别的地点

MAN的例子

il time 'Jul 01 1999 00:05:00';

e channel d1 type disk;

name for datafile '/u04/oracle/prod/sys1prod.dbf'

2/oracle/prod/sys1prod.dbf';

name for datafile '/u04/oracle/prod/usr1prod.dbf'

2/oracle/prod/usr1prod.dbf';

name for datafile '/u04/oracle/prod/tmp1prod.dbf'

2/oracle/prod/tmp1prod.dbf';

controlfile to '/u02/oracle/prod/ctl1prod.ora';

te controlfile from '/u02/oracle/prod/ctl1prod.ora';

database;

ter database mount\";

datafile all;

database;

ter database open resetlogs\";

channel d1;

从备份片(backuppiece)中恢复(restore)控制文件与数据文件

用如下方法,在RMAN中恢复备份片的控制文件

controlfile from backuppiecefile;

i的自动备份,可以采用如下的方法

controlfile from autobackup;

假如控制文件全部丢失,需要指定DBID,如SET DBID=?

份控制文件的默认格式是%F,这个格式的形式为

IIIII-YYYYMMDD-QQ,其中IIIIIIIIII就是DBID

复(restore)数据文件,oracle 816开始有个包dbms_backup_restore

unt 状态下就可以执行,可以读 815甚至之前的备份片,读出来的文件用于恢复

QLPLUS中运行,如下

rtup nomount

CLARE

pe varchar2(256);

boolean;

pe := dbms_backup_restore.deviceallocate('', params=>'');

backup_restore.restoresetdatafile;

backup_restore.restorecontrolfileto('E:\\Oracle\\oradata\\penny\\control01.ctl');

backup_restore.restoreDataFileto(1,'E:\\Oracle\\oradata\\penny\\system01.dbf');

backup_restore.restoreDataFileto(2,'E:\\Oracle\\oradata\\penny\\UNDOTBS01.DBF');

_backup_restore.restoreDataFileto(3,'E:\\ORACLE\\ORADATA\\PENNY\\USERS01.DBF');

_backup_restore.restorebackuppiece('D:\\orabak\\BACKUP_1_4_04F4IAJT.PENNY',done=>done);

过程已成功完成。

ter database mount;

的format格式中的%s类似的东西代表什么意义

参考如下

片的拷贝数

库名称

该月中的第几天 (DD)

该年中的第几月 (MM)

基于DBID唯一的名称,这个格式的形式为c-IIIIIIIIII-YYYYMMDD-QQ,其中IIIIIIIIII为该数据库的DBID,YYYYMMDD为日期,QQ是

库名称,向右填补到最大八个字符

八个字符的名称代表备份集与创建时间

份集中的备份片号,从1开始到创建的文件数

唯一的文件名,代表%u_%p_%c

集的号

集时间戳

日格式(YYYYMMDD)

exec dbms_logmnr_d.build('Logminer.ora','file Directory'),提示下标超界,怎么办

误信息如下,

ec dbms_logmnr_d.build('Logminer.ora','file directory')

bms_logmnr_d.build('Logminer.ora','file directory'); END;

位于第 1 行:

32: 下标超出限制

12: 在\"SYS.DBMS_LOGMNR_D\

12: 在line 1

法为:

辑位于\"$ORACLE_HOME/rdbms/admin\"目录下的文件\"dbmslmd.sql\"

l_desc_array IS VARRAY(513) OF col_description;

l_desc_array IS VARRAY(700) OF col_description;

文件

行改变后的脚本

> Connect internal

> @$ORACLE_HOME/rdbms/admin/dbmslmd.sql

新编译该包

> alter package DBMS_LOGMNR_D compile body;

execute dbms_logmnr.start_logmnr(DictFileName=>'DictFileName')提示ORA-01843:无效的月份,这个是什么原因

析start_logmnr包

RE start_logmnr(

n IN NUMBER default 0 ,

IN NUMBER default 0,

me IN DATE default TO_DATE('01-jan-1988','DD-MON-YYYY'),

IN DATE default TO_DATE('01-jan-2988','DD-MON-YYYY'),

eName IN VARCHAR2 default '',

IN BINARY_INTEGER default 0 );

道,假如TO_DATE('01-jan-1988','DD-MON-YYYY')失败,将导致以上错误

决办法可以为

ter session set NLS_LANGUAGE=American

类似如下的方法执行

dbms_logmnr.start_logmnr (DictFileName=> 'f:\emp2\\TESTDICT.ora', starttime => TO_DATE(

1988','DD-MM-YYYY'), endTime=>TO_DATE('01-01-2988','DD-MM-YYYY'));

因篇幅问题不能全部显示,请点此查看更多更全内容