ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle 学习总结(性能优化)

oracle 学习总结(性能优化)

原创 Linux操作系统 作者:zwc1083 时间:2009-02-27 08:13:44 0 删除 编辑

create controlfile [reuse] [set] database 数据库名 
logfile [group 
整数文件名 [,[group 整数文件名],...
对于现有的数据库,可以间接地通过
alter database backup controlfile to trace
命令生成控制文件,即可在\orant\rmb73\trace
下有ora00289.trc文件,其内容为文本

71
、日志管理 
<1>
建立日志组
sql>select * from v
logfile;
sql>alter database add logfile group 3
('f:\orant\database\log1_g3.ora'
'f:\orant\database\log2_g3.ora') size 100k;
sql>select * from v
logfile;
sql> alter database add logfile group 4
('/disk3/log4a.rdo','/disk4/log4b.rdo') size 1m; 
<2>
删除日志组
alter database drop logfile group 1;
但是其物理文件并没有被删除掉
系统至少需要2个日志组,如果只有2个,就不能删除
不能删除正活动的日志组
<3>
手工归档
通过alter system archive log 子句来实现
archive log [thread 
整数]
[seq 
整数][change 整数][current][group 整数]
[logfile '
文件名'][next][all][start][to '位置']
<4> 
强制日志切换 
sql> alter system switch logfile;
<5> 
强制checkpoints 
sql> alter system checkpoint; 
<6> adding online redo log members 
sql>alter database add logfile member 
'/disk3/log1b.rdo' to group 1, 
'/disk4/log2b.rdo' to group 2; 
<7>.changes the name of the online redo logfile 
sql> alter database rename file 'c:/oracle/oradata/oradb/redo01.log' 
to 'c:/oracle/oradata/redo01.log'; 
<8> drop online redo log members 
sql> alter database drop logfile member 'c:/oracle/oradata/redo01.log'; 
<9>.clearing online redo log files 
sql> alter database clear [unarchived] logfile 'c:/oracle/log2a.rdo'; 
<10>.using logminer analyzing redo logfiles 
a. in the init.ora specify utl_file_dir = ' ' 
b. sql> execute dbms_logmnr_d.build('oradb.ora','c:\oracle\oradb\log'); 
c. sql> execute dbms_logmnr_add_logfile('c:\oracle\oradata\oradb\redo01.log', 
sql> dbms_logmnr.new); 
d. sql> execute dbms_logmnr.add_logfile('c:\oracle\oradata\oradb\redo02.log', 
sql> dbms_logmnr.addfile); 
e. sql> execute dbms_logmnr.start_logmnr(dictfilename=>'c:\oracle\oradb\log\oradb.ora'); 
f. sql> select * from v
logmnr_contents(vlogmnr_dictionary,vlogmnr_parameters 
sql> v
logmnr_logs); 
g. sql> execute dbms_logmnr.end_logmnr; 

72 
系统控制
alter system ...

alter system enable restricted session; 只允许具有restricted系统特权的用户登录
alter system flush shared_pool 
清除共享池
alter system checkpoint 
执行一 个检查点
alter system set license_max_session=64,license_session_warning=54 
会话限制为64,会话的警界为54
alter system set license_max_session=0 
会话数为无限制
alter system set license_max_users=300 
用户限制为300
alter system switch logfile 
强制执行日志转换
73 
会话控制
alter session 

alter session set sql_trace=true 
当前会话具有sql跟踪功能
alter session set NLS_language=French 
出错信息设为法语
alter session set NLS_date_format='YYYY MM DD HH24:MI:SS';
缺省日期格式
alter session set optimizier_goal=first_row
改变优化方法为基于开销方法,具有快速响应速度
update student@teach set sold=sold+1 where sno='98010';
commit;
alter session close database link teach; 
关闭远程链路
74
、封锁机制
数据封锁:保护表数据,在多个用户并行存取数据时候,保证数据的完整性。
DML操作又在两个级别获取数据封锁:指定记录封锁和表封锁
表封锁可以有下列方式:行共享(RS),行排他(RX),共享封锁(S),共享行排他(SPX)和排他
封锁(X)
行共享表封锁(RS),允许其他事务并行查询、插入,修改和删除及再行封锁
select ...from 
表名 ... for update of ...;
lock table 
表名 in row share mode;
行排他表封锁(RX) 对该行有独占权利
insert into 
表名 ...;
update 
表名 ...;
delete from 
表名 ...;
lock table 
表名 in row exclusive mode;
允许并行查询、插入、删除或封锁其他行,但禁止其他事务使用下列命令进行并发封锁:
lock table 
表名 in share mode;
lock table 
表名 in share exclusive mode;
lock table 
表名 in exclusive mode;
共享表封锁(S)
lock table 
表名 in share mode;
允许其他事务可在该表上做查询和再实现共享表操作,但不能修改该表,同时也不能做如下封锁:
lock table 
表名 in share row exclusive mode;
lock table 
表名 in exclusive mode;
lock table 
表名 in row exclusive mode;
共享排他表封锁(SRX)
lock table 
表名 in share row exclusive mode;
排他表封锁(SRX)
lock table 
表名 in exclusive mode; 

75
、设置事务
set transaction [read only][read write][use rollback segment 
回滚段名]

76.
如果希望用aimtzmcc用户连接数据库,访问aicbs用户的表,不在表名前缀"aicbs.",可以在建立数据库连接后发下面的命令
alter session set current_schema = aicbs;

77
、表空间管理 
<1> 
创建表空间
sql> create tablespace tablespace_name datafile 'c:\oracle\oradata\file1.dbf' size 100m, 
sql> 'c:\oracle\oradata\file2.dbf' size 100m minimum extent 550k [logging/nologging] 
sql> default storage (initial 500k next 500k maxextents 500 pctinccease 0) 
sql> [online/offline] [permanent/temporary] [extent_management_clause] 
<2>.locally managed tablespace 
sql> create tablespace user_data datafile 'c:\oracle\oradata\user_data01.dbf' 
sql> size 500m extent management local uniform size 10m; 
<3>.temporary tablespace 
sql> create temporary tablespace temp tempfile 'c:\oracle\oradata\temp01.dbf' 
sql> size 500m extent management local uniform size 10m; 
<4>.change the storage setting 
sql> alter tablespace app_data minimum extent 2m; 
sql> alter tablespace app_data default storage(initial 2m next 2m maxextents 999); 
<5>.taking tablespace offline or online 
sql> alter tablespace app_data offline; 
sql> alter tablespace app_data online; 
<6>.read_only tablespace 
sql> alter tablespace app_data read only|write; 
<7>.droping tablespace 
sql> drop tablespace app_data including contents; 
<8>.enableing automatic extension of data files 
sql> alter tablespace app_data add datafile 'c:\oracle\oradata\app_data01.dbf' size 200m 
sql> autoextend on next 10m maxsize 500m; 
<9>.change the size fo data files manually 
sql> alter database datafile 'c:\oracle\oradata\app_data.dbf' resize 200m; 
<10>.Moving data files: alter tablespace 
sql> alter tablespace app_data rename datafile 'c:\oracle\oradata\app_data.dbf' 
sql> to 'c:\oracle\app_data.dbf'; 
<11>.moving data files:alter database 
sql> alter database rename file 'c:\oracle\oradata\app_data.dbf' 
sql> to 'c:\oracle\app_data.dbf'; 

78
BACKUP and RECOVERY 

<1>. v
sga,vinstance,vprocess,vbgprocess,vdatabase,vdatafile,vsgastat 

<2>. 
Rman need set dbwr_IO_slaves or backup_tape_IO_slaves and large_pool_size 

<3>. Monitoring Parallel Rollback 
v
fast_start_servers , vfast_start_transactions 

<4>.perform a closed database backup (noarchivelog) 
shutdown immediate 
cp files /backup/ 
startup 

<5>.restore to a different location 
connect system/manager as sysdba 
startup mount 
alter database rename file '/disk1/../user.dbf' to '/disk2/../user.dbf'; 
alter database open; 

<6>.recover syntax 
--recover a mounted database 
recover database; 
recover datafile '/disk1/data/df2.dbf'; 
alter database recover database; 
--recover an opened database 
recover tablespace user_data; 
recover datafile 2; 
alter database recover datafile 2; 

<7>.how to apply redo log files automatically 
set autorecovery on 
recover automatic datafile 4; 

<8>.complete recovery: 
--method 1(mounted databae) 
copy c:\backup\user.dbf c:\oradata\user.dbf 
startup mount 
recover datafile 'c:\oradata\user.dbf; 
alter database open; 
--method 2(opened database,initially opened,not system or rollback datafile) 
copy c:\backup\user.dbf c:\oradata\user.dbf (alter tablespace offline) 
recover datafile 'c:\oradata\user.dbf' or 
recover tablespace user_data; 
alter database datafile 'c:\oradata\user.dbf' online or 
alter tablespace user_data online; 
--method 3(opened database,initially closed not system or rollback datafile) 
startup mount 
alter database datafile 'c:\oradata\user.dbf' offline; 
alter database open 
copy c:\backup\user.dbf d:\oradata\user.dbf 
alter database rename file 'c:\oradata\user.dbf' to 'd:\oradata\user.dbf' 
recover datafile 'e:\oradata\user.dbf' or recover tablespace user_data; 
alter tablespace user_data online; 
--method 4(loss of data file with no backup and have all archive log) 
alter tablespace user_data offline immediate; 
alter database create datafile 'd:\oradata\user.dbf' as 'c:\oradata\user.dbf' 
recover tablespace user_data; 
alter tablespace user_data online 
<9>.perform an open database backup 
alter tablespace user_data begin backup; 
copy files /backup/ 
alter database datafile '/c:/../data.dbf' end backup; 
alter system switch logfile; 
<10>.backup a control file 
alter database backup controlfile to 'control1.bkp'; 
alter database backup controlfile to trace; 
<11>.recovery (noarchivelog mode) 
shutdown abort 
cp files 
startup 
<12>.recovery of file in backup mode 
alter database datafile 2 end backup; 

<13>.clearing redo log file 
alter database clear unarchived logfile group 1; 
alter database clear unarchived logfile group 1 unrecoverable datafile; 

<14>.redo log recovery 
alter database add logfile group 3 'c:\oradata\redo03.log' size 1000k; 
alter database drop logfile group 1; 
alter database open; 
or >cp c:\oradata\redo02.log' c:\oradata\redo01.log 
alter database clear logfile 'c:\oradata\log01.log';

79 managing password security and resources 

<1>.controlling account lock and password 
sql> alter user juncky identified by oracle account unlock; 

<2>.user_provided password function 
sql> function_name(userid in varchar2(30),password in varchar2(30), 
old_password in varchar2(30)) return boolean 

<3>.create a profile : password setting 
sql> create profile grace_5 limit failed_login_attempts 3 
sql> password_lock_time unlimited password_life_time 30 
sql>password_reuse_time 30 password_verify_function verify_function 
sql> password_grace_time 5; 

<4>.altering a profile 
sql> alter profile default failed_login_attempts 3 
sql> password_life_time 60 password_grace_time 10; 

<5>.drop a profile 
sql> drop profile grace_5 [cascade]; 

<6>.create a profile : resource limit 
sql> create profile developer_prof limit sessions_per_user 2 
sql> cpu_per_session 10000 idle_time 60 connect_time 480; 

<7>. view => resource_cost : alter resource cost 
dba_Users,dba_profiles 

<8>. enable resource limits 
sql> alter system set resource_limit=true; 

80.managing privileges 

<1>.system privileges: view => system_privilege_map ,dba_sys_privs,session_privs 

<2>.grant system privilege 
sql> grant create session,create table to managers; 
sql> grant create session to scott with admin option; 
with admin option can grant or revoke privilege from any user or role; 

<3>.sysdba and sysoper privileges: 
sysoper: startup,shutdown,alter database open|mount,alter database backup controlfile, 
alter tablespace begin/end backup,recover database 
alter database archivelog,restricted session 
sysdba: sysoper privileges with admin option,create database,recover database until 

<4>.password file members: view:=> v
pwfile_users 

<5>.O7_
dictionary_accessibility =true restriction access to view or tables in other schema 

<6>.revoke system privilege 
sql> revoke create table from karen; 
sql> revoke create session from scott; 

<7>.grant object privilege 
sql> grant execute on dbms_pipe to public; 
sql> grant update(first_name,salary) on employee to karen with grant option; 

<8>.display object privilege : view => dba_tab_privs, dba_col_privs 

<9>.revoke object privilege 
sql> revoke execute on dbms_pipe from scott [cascade constraints]; 

<10>.audit record view :=> sys.aud
 

<11>. protecting the audit trail 
sql> audit delete on sys.aud
 by access; 

<12>.statement auditing 
sql> audit user; 

<13>.privilege auditing 
sql> audit select any table by summit by access; 

<14>.schema object auditing 
sql> audit lock on summit.employee by access whenever successful; 

<15>.view audit option : view=> all_def_audit_opts,dba_stmt_audit_opts,dba_priv_audit_opts,dba_obj_audit_opts 

<16>.view audit result: view=> dba_audit_trail,dba_audit_exists,dba_audit_object,dba_audit_session,dba_audit_statement 

81 manager role 

<1>.create roles 
sql> create role sales_clerk; 
sql> create role hr_clerk identified by bonus; 
sql> create role hr_manager identified externally; 

<2>.modify role 
sql> alter role sales_clerk identified by commission; 
sql> alter role hr_clerk identified externally; 
sql> alter role hr_manager not identified; 

<3>.assigning roles 
sql> grant sales_clerk to scott; 
sql> grant hr_clerk to hr_manager; 
sql> grant hr_manager to scott with admin option; 

<4>.establish default role 
sql> alter user scott default role hr_clerk,sales_clerk; 
sql> alter user scott default role all; 
sql> alter user scott default role all except hr_clerk; 
sql> alter user scott default role none; 

<5>.enable and disable roles 
sql> set role hr_clerk; 
sql> set role sales_clerk identified by commission; 
sql> set role all except sales_clerk; 
sql> set role none; 

<6>.remove role from user 
sql> revoke sales_clerk from scott; 
sql> revoke hr_manager from public; 

<7>.remove role 
sql> drop role hr_manager; 

<8>.display role information 
view: =>dba_roles,dba_role_privs,role_role_privs,dba_sys_privs,role_sys_privs,role_tab_privs,session_roles 

81.
查询当前正在执行的job的情况
有时候对于需要执行的job查询执行情况,比如正在执行那条语句,或者想把job停下来等。一般不知道怎么查询到
job
执行的sessionsid.
方法一:
select * from dba_jobs_running 
如果运行比较慢,加

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14876437/viewspace-558009/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2009-02-16

  • 博文量
    91
  • 访问量
    46563