15天的OCP培训笔记
第一天
7月13日OCP笔记:
Oracle Ocp11g准备资料:
OracleFundmentals 书
管理1 书
管理2 书
光盘下载:otn.oracle.com
文档下载:docs.oracle.com
虚拟机配置:1cpu/2G RAM/OracleLinux/网络HostOnly/40G SATA。安装OracleEnterpriseLinux5.4,Oracle11gR2 11.2.0.1。E盘没还原卡。
操作系统:语言选英文(免环境变量NLS_LANG)静态IP:200.100.50.13/24,主机名server13.example。时区:上海,不用UTC。密码codecraft。软件全选。关闭防火墙,SELinux禁用。Kdump内核转储不选。不创建帐户。分辨率1024*758(系统-管理-显示-硬件-LCD-1024*768,首页也要改,改后重启)。
装Oracle11gR2:
建组 oinstall dba oper 用户oracle/密码oracle1158
建目录/u01/app/oracle,改所有者,改权限775
加环境变量:
umask 022
export TMP=/tmp
export TMPDIR=/tmp
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1
export ORACLE_SID=orcl
export PATH=.:$ORACLE_HOME/bin:$PATH
安装包拷到/tmp目录下。进oracle帐户,执行xhost+,$cd /;./runInstaller;
Create and configure the database
Server Class
单实例single Instance
装包 包在Linux光盘的Server目录
SQL语句:
查询 SELECT
数据维护DML INSERT UPDATE DELETE
数据定义DDL CREATE ALTER DROP TRUNCATE
数据控制DCL GRANT REVOKE
事务控制TCL COMMIT ROLLBACK SAVEPOINT
解锁用来学习Oracle的hr帐户:
SQL>alter user hr identified by "hr" account unlock;
查书《SQL Language Reference》
进入sqldeveloper:
#xhost +
#su - oracle
$ORACLE_HOME/sqldeveloper/sqldeveloper.sh
设置:连接名hr,用户名hr,密码hr,SID为orcl。测试应该状态成功。
按F9执行sql语句。Sqldeveloper命令可修改,带Tab自动补齐和Ctrl+BackSpace删单词使用更方便。
显示用户:
>show user
不同帐户有不同的表,只有hr帐户有employess表,而sysdba中没有。
用数据字典显示所有的表:
>select table_name from dba_tables;//管理员的拥有表
>select table_name from user_tables;//用户的拥有表
查看表结构(相看表有哪些列):
>desc 表名
相看表内容:
>select语句
关键字和对象名不区分大小写,换分是任意的。
查询:
>select 列|表达式 from 表;//表达式不影响原表
查询的列别名AS "别名":解
>select first_name,last_name,salary*12 as "nianxin" from employees;
一般表达式都是加别名便于理。别名可以不加引号,但有空格的别名必须加引号。
查询的去重复行:
>select distinct department_id from employees;
注意:表达式中与NULL有关的任何计算均为NULL。
双坚线字符串连接用双坚线||
当字符串间中单引号,使用q'[]'括起字符串。
每课的练习只有英文版中才有。作业为Practice for lesson1。
第二天
7月14日OCP笔记:
数据类型:NUMBER DATE VARCHAR2
DATE要求单引号界定,大小写区分,格式满足要求。
ORA-27300错误导致无法启动数据库,需要修改内核参数#vim /etc/sysctl.conf加入kernel.sem=250 32000 100 128完成。
关键字、表名、列名都不区分大小写。
选92年之后进公司的:(使用日期)
>select first_name,last_name,salary from employees where hire_date='01-JAN=92';
查看没有提成的:(IS NULL筛选)
>select first_name,last_name,salary from employees where commission_pct IS NULL;
按薪水排序:
>select first_name,last_name,salary from employees order by salary desc;
查询名字中第2个字母为a的员工:
>... where last_name like '_a%';
IN关键字与OR功能有重复:
>salary IN(5000,6000,7000)同salary=5000 OR salary=6000 OR salary=7000
&变量替换可以替换列名或表达式
>select first_name,last_name,&v1 from employees where hire_date>'01-JAN-92' order by &v2 desc;
PL/SQL最常用功能:条件判断,循还。还有函数,存储过程,包,触发器。
单行函数,转换函数,组函数可以无需PL/SQL编程,直接实现常用功能。
单行函数单进单出,多行函数则是多入单出。功能在SQL Language Reference中的Function查询。
虚拟表dual用于构造完整语句:
>select upper('abcdefg') from dual;
年YYYY,而年缩写YY/RR不易用不建议使用。
加月:
>select add_month(sysdate 1) from dual;
下周五:
>select next_day(sysdate 'FRIDAY') from dual;
月份最后一天:
>select last_day(sysdate) from dual;
日期四舍五入:
>select round(sysdate,'YEAR') from dual;
>select trunc(sysdate,'MONTH') from dual;
Sqlplus保存文件:(需要创建目录)
>save /test.sql;不填路径默认存在/home/oracle路径下。
运行Sqlplus:
>@/test.sql;
编缉.sql文件用VIM编缉器,另存为方式如下:
Shift+:w /test2.sql
答疑:
字串中有'用其它引号运算符q'[]'。字串、日期用单引号,列别名用双引号。筛选%和_用逃脱转义符like '%Smi\_th%' ESCAPE '\'。
使用sys用户登sqldeveloper需将Role换为sysdba。
显示转换:
>select 123+'234' from dual;//相当于123+to_number('234')
显示转换自定义日期格式:
select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') from dual;
显示转换区分大小写,以下两条语句不同:
>select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS YEAR') from dual;
>select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS Year') from dual;
自定义的字符串放到日期格式之间用""
>select to_char(sysdate,'YYYY-MM-DD "of" HH24:MI:SS') from dual;
格式ddspth,dd数字日期,sp拼写,th排序:
>...
使用fm删除前导空格:
>...
数字显示转换为字符:
>select to_char(12345678,'$99,999.00') from dual;
注意任意长度数字占位小于数字将无法显示。
to_number几乎不用。
to_date使用:隐式转换可能报错,因而最好加上。
>...where hire_date
nvl(exp1,exp2)当表达式1不为空返表达式exp2:
nvl2(exp1,exp2,exp3)当表达式1不为空返表达式exp2,为空返表达式exp3:
nullif(exp1,exp2)比较两个表达式,不等返回表达式1,相等返回空。
coalesce(exp1,exp2,exp3)返回第一个非空值。
CASE条件表达式:
>select lst_name,salary,CASE department_id WHEN 10 THEN salary+1000 WHEN 20 salary+2000 WHEN 30 salary+3000 ELSE salary+500 END AS "New Salary" from employees;
DECODE条件表达式:
>select lst_name,salary,decode department_id,10,salary+1000,20,salary+2000,30,salary+3000,salary+500 as "NewSalary" from employees;
第三天
7月15日OCP笔记:
子查询内容:
查询员工名字,工资(比Jones低的):
>select last_name,salary from employees where salary<(select salary from employees where last_name='Jones');
在查询的结果中再进行查询。单行子查询的结果是一行一列,多行子查询的结果是多行一列。多列结果只能分割为一列。
子查询用途1:放到比较条件中,单行子查询常配合组函数使用。
单行比较运算符:> < >= <=
多行比较运算符:>ALL ANY大于最小
子查询用途2:放在被查询表处
select last_name,salary from (select last_name,salary from employees);
集合运算符:UNION/UNION ALL;INTERSECT;MINUS
例子:
>create table a (id number,name char(10));
>create table b (id number,name char(10));
>insert into a values(10,'aa');
>insert into a values(20,'bb');
>insert into b values(10,'aa');
>insert into b values(30,'cc');
>select * from a union select * from b;
处理数据包括: DML数据操作语句和TCL事务处理语句。
create table 表/列,insert into 表/值,update表set的列赋值,delete表/条件。建表的表名和列名加与不加空格都可以。insert into表列行用于添加缺少部分列信息的行,也可以在VALUES子句中填NULL。
表中插入单行:
>desc table1;//先查询表结构,再方便插入行数据。
>insert into employees values(行值);
些语法一次只能插入一行。列名是可选参数一般不填,空值填NULL。
创建一个同结构的空表:
>create table emp as select * from employees where 1=2;
表中一次插入多行,也就是将子查询结果插入到表中:
>insert into emp select * from employees where department_id=50;
子查询结果的结构要与被录入表的结构一致。若只录入前10前:where rollnum<11;
修改数据:
>update emp set salary=10000,comission_pct=0.1;
删除数据:
>delete emp where salary>5000;
清空表。删除所有表内容,表还在:
>delete emp;删除表内容的DML语句
>truncate table emp;//此为DDL语句
DDL语句:truncate;create;alter;drop;
DC语句:grant;revoke;
TCL事务控制语句:commit;rollback;savepoint;select for update;
事务特征ACID:原子性,一致性,隔离性,持久性。多条DML都是一个事务、一条DDL、一条DCL。也就是说DDL、DCL语句自动提交(隐式提交)。正常退出也会自动提交。系统崩溃则回滚rollback。
select for update;锁定被修改的行直到commit或update才释放。
模拟崩溃:
#ps ef|grep oracleorcl;//查看进程号
#kill -9 进程号;
练习:建表,录入10行,试下不同的提交方式。
标记保存点:
>savepoint p1;
回滚到保存点:
>rollback p1;
利用伪列选择前10行:
>select * from employees where rownum<11;
只有提交的数据才能被其它用户可见。修改的未提交数据,其它用户不可修改,只能访问修改前的数据。
读一致性:读取的数据为查询命令的执行时间的数据。在数据区实现修改,修改前数据通过构造CR块实现。
SELECT是无锁,DML会产生锁,锁为行锁。commit将释放行锁。
DDL语句。
命名规则:30个字符以内,同一用户不能重名,只含字母数字_#$,首不为数,不含保留字。
查看用户:
>desc dba_users;//要求SYSDBA权限
>select username from dba_users;
查看保留字:
>desc v$reserved_words;//要求SYSDBA权限
>select * from v$reserved_words where reserved='Y';//保留字多数是关键字
建表,要求有存储空间和权限:
>create table hr.students (stu_id number,stu_name varchar2(20),stu_sex char(1) DEFAULT 'M');
DEFAULT参数填入默认值。
数据类型:number date 定长char(2000Byte) 可变字串varchar2(4000Byte) CLOB(charactor larger object 约4Gbyte)。
查看块大小:
>show parameter db_block_size;
时间间隔的数据类型:INTERVAL YEAR TO MONTH;INTERVAL DAY TO SECOND
添加列:格式(alter table 表 add 表)
>alter table students add resume clob;
>desc students;
建表约束条件,用于建表的列名后:constraint+约束名+约束类型
NOT NULL不空
UNIQUE不重,允许为空
PRIMARY KEY不重不空
FOREIGN KEY外键的值只能为参考主键值或NULL
CHECK自定义检查
约束用于限制表中数据的有效性。
NOT NULL约束:(NOT NULL约束直接附在列名后)
>create table t1(id number NOT NULL,name char(10));
>create table t2(id number,name char(10));
>alter table t2 modify id number NOT NULL;
UNIQUE约束:
>create table t3 (id number constraint t3_id_un UNIQUE,name char(10));
>create table t4 (id number name char(10));
>alter table t4 add constraint t4_id_un UNIQUE(id);
主键约束用法:(建表的constraint+约束条件名+约束类型,改表的constraint+约束条件名+x约束类型括进列名)
>create table t5 (id number constraint t5_id_pk primary key,name char(10));
>create table t6 (id number,name char(10));
>alter table t6 add constraint t6_id_pk primary key(id);
外键约束用法:(constraint+约束条件名+references+主键表(主键列))
>cerate table classes (id number constraint class_id_pk primary key,class_name char(10));
>drop table students
>create table sutdents (stu_id number,stu_name char(10),class_id number constraint stu_classid_fk references classes(class_id));//建表外键约束写在内部
>create table sutdents (stu_id number,stu_name char(10),class_id number,constraint stu_classid_fk foreign key(class_id) references classes(class_id));//建表外键约束写在外部
>create table students1 (stu_id_number,stu_name char(10),class_id number);
>alter table students1 add constraint stu1_classid_fk foreign key(class_id) references classes(class_id);
注意建表外键约束写在外部同修表形式,若写在内部不能加数据类型和foreign key关键字。否则将出现ora-02253错误,“这里不允许限制声明”。
教材31页可以练习创建主外键的关系。
检查约束:
>alter table students add stu_age number(2);
>alter table students add constraint ck_age CHECK(stu_age between 12 AND 18);
>alter table students add stu_sex char(1) constraint ck_sex CHECK (stu_sex IN('M','F','m','f'));
复合主键:
>create table t8 (id2 number,name char(10) constraint t8_pk primary key(id1,id2));
用数据字典查看表的主外键关系:
>select table_name from user_tables;//查看表名
>select constraint_name,constraint_type from user_constraints where table_name='classes';//查看约束关系
第四天
160718第四天OCP笔记
ON DELETE CASCADE参数,联动修改,删除主键相关行同时删除外键相关行:
SQL> alter table students drop constraint STU_CLASSID_FK;
SQL> alter table students add constraint STU_CLASSID_FK foreign key(class_id) references classes(class_id) on delete cascade;
ON DELETE SET NULL参数,联动修改,删除主键相关行同时将外键相关行置NULL:
SQL> alter table students drop constraint STU_CLASSID_FK;
SQL> alter table students add constraint STU_CLASSID_FK foreign key(class_id) references classes(class_id) on delete set null;
添加列:
>alter table students add resume clob;
删除列:
>alter table students drop resume;
重命名列:
>alter table students rename resume resume1
修改列定义:
>alter table students modify resume varchar2(4000);
修改列默认值、列约束条件的内容前面讲过。
创建视图:
>create view v1 as select * from employees;
视图本质上就是封闭一条查询语句。视图也可也像表那样用select desc。
视图不能删除,只能删除再创建:(两种方法)
>drop view v1;
>create view v1 as select * from employees;//方法1
>create or replace as ...;//方法2
创建视图问题:
>create or replace v1 as select * from employees;
WITH CHECK OPTION子句,对视图的DML操作限定在视图范围内,超出范围将被拒绝:
>create or replace v1 as select last_name,salary from employees where salary>15000 with check option;
>update v1 set sal=12000 where last_name='Kochhar';//若不加with check option参数,修改后值将不可见,添加此参数将拒绝修改。
创建只读视图:
>create or replace v1 as select last_name,salary from employees where salary>15000 with read only;
删除视图:
>drop view v1;
简单视图的基表只能是1个,不包含函数,不分组。
视图包含以下内容不能删除行:DISTINCT、伪列rownum、组函数。
视图包含以下内容不能修改行:DISTINCT、伪列rownum、组函数以及表达式定义的列。例如salary*12为表达式定义的列。
视图包含以下内容不能添加行:DISTINCT、伪列rownum、组函数、表达式定义的列以及没有包含NOT NULL列。
SEQUENCE序列。
>create sequence seq1 increment by 3 start with 0 maxvalue 50 cycle cache 10;//参数cache指一次算10个,供后面使用。
>create table test001(id int);
>insert into test001 values(id,sql.nextval);
>使用数据字典user_sequence查看sequence当前值
索引。
索引可以自动创建或手动创建,自动使用。全内存数据库不需要创建索引。且索引增加DML负担,浪费系统资源。
数据库查询有全表扫描和索引扫描,等方式。Oracle根据执行计划进行成本判断决定是否使用索引。当具有索引且索引有助于(执行方案选优)查询才使用索引。
例如select count(*) from t1;是用全表扫描的,当有where条件时可能用索引。
以某一列创建索引:
>create index inx_test001_id on test_001(id);
创建索引的情况:列值范围很广,列中包含大量的空值,在where子句频繁用表的列尤其是多表联接的等值联接条件,表很大(万行以上)却查询结果小于4%。
OLPT系统改的多查的少,一般不建索引。
upper(last_name)='SMITH'代替last_name='Smith'会解决输入大小写的问题,但不再使用索引。
同义词:
>create synonym emp for employees;
>create pulbic synonym e1 for hr.employees;//需要sysdba权限,创建所有人都可以使用的同义词。
第一章 了解Oracle体系结构
Oracle Server=Oracle Instance(运行时)+Oracle Database(存储上)
Oracle Instance=Processes+Memory
Processes=ServerProcess+BackgrountProcess。服务进程为用户所拥有
查看Oracle服务进程:
>ps -ef|grep|oracleorcl
查看后台进程:
>ps -ef|grep ora_
研究5个关键的后台进程:
Process Monitor 即ora_pmon_orcl 作用:注册服务器、回收资源
System Monitor 即ora_smon_orcl 作用:实例恢复,合并空间
Database Writer 即ora_dbw0_orcl 作用:将内存中的数据写回磁盘
Log Writer 即ora_lgwr_orcl 作用:将内存中的日志写回磁盘
Checkpoint 即ora_ckpt_orcl 作用:同步数据文件、日志文件、控制文件,使数据库达到一致性。
Memory:一个共享区域(System Global Area SGA)和N个私有区域(Progrram Global Area PGA)。
SGA划分:database buffer cache、redo log buffer、shared pool、java pool、stream pool、large pool。
large pool用于支持备份恢复、数据装载、数据导入导出、并行查询或DML操作。
java pool用于支持java虚拟机。
streams pool支持流服务。
PGA用于存放会话信息、权限、变量、堆栈。
存储:filesystem/ASM裸设备/RAW/NFS/NAS/SAN...
数据库文件:数据文件、日志文件、控制文件、参数文件。归档日志文件、备份文件、口令文件、
参数文件存放位置:
$ORACLE_HOME/dbs/spfile$ORACLE_SID.ora。用于启动Oracle Instance。
数据文件存放位置:
>select name from v$datafile;
>select name from v$tempfile;
日志文件存放位置:
>select nember from v$logfile;
控制文件:
>select name from v$controlfile;
口令文件:
$ORACLE_HOME/dbs/orapworcl.ora;
进程跟踪及预警文件:
/u01/app/oracle/diag/rdbms/orcl/orcl/trace;//进程跟踪文件
/u01/app/oracle/diag/rdbms/orcl/orcl/trace/alert_orcl.log;//预警文件
实施ASM存储后性能和容错性会提升。
安装独立于服务器的Oracle Grid Infrastructor:
安装Linux
创建组:asmadmin asmdba asmoper oinstall dba oper
创建帐号:#useradd grid -g oinstall -G asmadmin,asmdba,asmoper,dba;useradd oracle -g oinstall -G asmdba,dba,oper
(注意用户组要加对,否则无法添加ASM磁盘组,id grid;id oracle查组,usermod -a G dba grid添加组)
建目录:/u01/app/grid;/u01/app/oracle。拥有者:grid:oinstall /u01;oracle:oinstall /u01/app/oracle。权限:775。
环境变量修改部分:export $ORACLE_BASE=/u01/app/grid;export $ORACLE_HOME=/u01/app/grid/product/11.2.0/gridhome_1;ORACLE_SID=+ASM
准备ASM磁盘:40G,平均分11个区。
查看Linux内核版本:#uname -r
安装ASMLib:#rpm -ivh /光盘目录/*;
配置ASMLib服务:#/etc/init.d/oraleasm configure; 参数:grid/asmadmin/y/y。注意当前目录执行要用./oracleasm configure;
转化为ASM磁盘:#/etc/init.d/oraleasm createdisk asmdisk01 /dev/sdb1;//注意sdb4分区是扩展区不能使用,注意是ROOT用户
asmdisk01 /dev/sdb1
asmdisk02 /dev/sdb2
asmdisk03 /dev/sdb3
asmdisk04 /dev/sdb5
asmdisk05 /dev/sdb6
...
asmdisk10 /dev/sdb11
查看ASM磁盘:#/etc/init.d/oraleasm listdisks;
删除ASM磁盘#/etc/init.d/oracleasm deletedisk asmdisk18
DATA Normal asmdisk01-04
FRA External asmdisk05-08
安装grid软件:
#su - grid
$.../clusterware/Disk1/runInstaller;//执行安装
选:Install and Configure Grid Infrastructor for a Standalone Server;数据磁盘选DATA Normal;口令;其它同Oracle安装
用grid帐户执行$asmca;把5-8磁盘选成FRA。
($sqlplus / as asmdba;>startup;//启动ASM实例)
安装OracleDatabase软件:
Oracle用户下运行./runInstaller,只安装不建库,单实例数据库(不选RAC,real application cluster),执行脚本参数为缺省的不覆盖。
建库:
$dbca,General模板(General为OLPT模板,DATA为仓库模板)。全局数据库名任意起名,SID与环境变量一致。EM用database control(不用grid control)。密码。
Storage Tyep用ASM,Darabase Area用+DATA,ASM口令。recovery option的flash recovery area设置为FRA(主要用来放备份文件),不选EnableArchiving。
勾选Samples,内存(默认)、进程数(默认)、字符集(AL32UTF8)、ConnectionMode(默认)。
勾选建库,存模板,存建库脚本。EM解锁。
第五天
160719第五天OCP笔记
init.ohasd(包装进程):实现自动启动监听、ASM实例、数据库实例。
数据库逻辑结构:数据库-表空间-段-区-块。段是空间分配单元。表不够用时,以区为单位扩展。一般SYSTEM、SYSTEMAUX不用来存数据。
查看表空间名:
>select tablespace_name from dba_tablespaces;//需要SYSDBA权限
查看表空间名及文件名:
>select tablespace_name,file_name from dba_data_files;
向指定表空间建表:
>create table test (id number,name varchar(10)) tablespace users;
修改表的列宽
>col segment_name for a10;
查看表所在表空间、表、段、区、块:(表空间是users,而所有者是SYS)
>select tablespace_name,segment_name,blocks,extents,bytes/1024/1024 from dba_segments where owner='SYS' and segment_name='TEST';//注意SYS大写,表名也必需大写,不能用通配符?
循还录入数据(注意加/执行):
>begin
for i in 1..1000 loop
insert into test values(i,'aa');
end loop;
commit;
end;
/
启动监听:无GI用oracle帐号 lnsrctl start,有GI用grid帐号。再启数据库、EM(EM启动需要创建安全例外)。
执行脚本:>sqlplus hr/hr@scripts.sql
数据库分阶段诊断启动:过程instance started;database mounted;database open;
>start nomount;//若执行startup mount直接执行到第2阶段
>alter database mount;
>alter database open;
数据库4种关闭方式。生产环境多用shutdown transactional。shutdown abort则再启动由SMON实例恢复。
命令startup force=shutdown abort+startup
参数含义查看文档,改参数:
>alter system set sga_max_size=800M scope=both;//scope值memory、spfile、both
查看内存参数:
>show parameter sga_max_size;
查看磁盘参数文件:
#strings $ORACLE_HOME/dbs/spfileorcl.ora;//文件系统
#strings +DATA/orcl/spfileorcl.ora;//ASM设备
其中sp指separate physical
SQL清屏:
>!clear;
Oracle运维需要查看:
1、预警文件 运行常规信息
1、进程跟踪文件 各类进程,用地排错
3、动态性能视图 日常性能监控 内存表的视图
4、数据字典视图 数据库的物理和逻辑信息 数据字典的视图
从References 的PartIII Dynamic Performance View
动态性能视图:
用v$sql保存最近执行的SQL语句:
>select sql_text,executions from v$sql where cpu_time>200000;
用v$session查看登录的会话:
用v$lock查询锁信息:
>select sid,ctime from v$lock where block>0;
数据字典视图(都是复数):
查看用户拥有的表:
>select table_name from user_tables;
>select table_name from dba_tables;//查看所有用户拥有的表
其它表dba_users、all_sequences、dba_indexes。
查看预警文件:EM-AlertHistory。
/*--------------------------------------------------------------------------------------------------------------------
ASM的磁盘组在数据库建立之前用命令行管理,数据库建立之后用EM或SQLPLUS管理。
实例管理ASM磁盘组(SQLPLUS):
grid帐号运行sqlplus / as asmdba;
用v$asmdisk v$asm_diskgroup查看ASM磁盘使用情况:
>select group_number,name from asm$disk;
建磁盘组(4块):
>create diskgroup DG1 normal redundancy disk 'asmdisk09','asmdisk10','asmdisk11','asmdisk12';//redundancy指冗余
再次查看磁盘组:
>select group_number,name from asm$disk;
添加/删除磁盘组:
>alter diskgroup dg1 add/drop disk 'asmdisk13';
同时添加删除磁盘(经常用于换盘,用一条执行的更快):
>alter diskgroup DG1 add disk 'asmdisk14' drop disk 'asmdisk12';
删除磁盘组:
>drop diskgroup dg1;
实例管理ASM磁盘组(EM):
进入General下的ASM,删除ASM磁盘要force。
创建磁盘组参数:
Redundancy冗余参数有high(至少三块磁盘)、normal(至少两块磁盘)、external(不冗余至少一块磁盘)
Allocation Unit分配单元
创建故障组(EM):选若干块磁盘,FailureGroup起相同的名字。
创建故障组(SQLPLUS):
>create diskgroup dg normal redundancy failgroup f1 disk 'asmdisk09','asmdisk10';
>create diskgroup dg normal redundancy failgroup f2 disk 'asmdisk10','asmdisk11';
区映射:只了解。
ASM磁盘组的兼容性:DATA/FRA/DG磁盘组由“ASM实例-Grid”管理,由“数据库实例-OracleDatabase”使用。
创建磁盘组时OracleDatabase版本<'compatible.rdbms'<'compatible.asm'<=Grid版本。兼容版本越低性能越差。
重平衡REBALANCE,数据平均分配到磁盘上。
创建表空间
>create tablespace tbs1 datafile '+FRA';
删除磁盘后每个磁盘内容变多:
>alter diskgroup FRA drop disk 'asmdisk08';
ASM快速镜像重新同步:当磁盘离线
实例管理ASM磁盘组(命令行)(在数据库建立之前使用):
grid$asmca;
grid$asmcmd;
课后练习5.1。需要将Oracle安装光盘的labs目录下。
第六天
160720第六天OCP笔记
/*网络配置-------------------------------------------------------------------------------------------------------------------------------------------------
netmgr中的名字解释:HostName主机名、ServiceName数据库全局服务名、SID为$ORACLE_SID。
对于单实例数据库,Oracle Server、Oracle Listener在同一台服务器。
listener.ora提供以下信息:监听器名、IP、端口、数据库服务名。
生成监听listener.ora:无GI用orcle有GI用grid帐户。$netmgr;添加Listeners,主机IP(用静态加快访问速度)、端口、GlobalDatabaseName填数据库全局名、填$ORACLE_SID。
注意监听配好后要启动监听,多监听启动要指定监听名。
生成tnsnames.ora:无GI有GI用oracle帐户。$netmgr;添加Service Naming,NetServiceName填网络服务名,主机IP,端口号,ServiceName填数据库全局名。
注意listener.ora的参数要与已配好监听相同。
文本编缉监听器$vim $ORACLE_HOME/network/admin/listener.ora;$vim $ORACLE_HOME/network/admin/tnsnames.ora;有GI与无GI的区别是$ORACLE_HOME不同。
文本编缉第2个监听器的名字不同、端口号不同、去掉IPC通讯的一行(第一个监听器IPC保留),其它的相同。由Process Monitor提供注册服务。
查数据库全局名>show parameter service_names
显示$ORACLE_HOME:echo $ORACLE_HOME
显示$ORACLE_SID:echo $ORACLE_SID
查看监听是否提供服务:$lsnrctl status listener2;
通过进程间通信而不通过网络访问数据库:
$sqlplus hr/hr;
$sqlplus / as sysdba;
使用监听访问数据库(简单访问):
$sqlplus hr/hr@IP:1521/orcl
$sqlplus sys/oracle@IP:端口/数据库全局服务名 as sysdba;
通过使用不同的端口使用不同的监听器。
使用监听和tnsnames.ora访问数据库():
$sqlplus hr/hr@网络服务名;
$sqlplus sys/oracle@网络服务名 as sysdba;
专用服务器进程:
查看服务器进程:
>show parameter processes;//查看全部进程
>ps -ef|grep ora_;//查看后台进程
设置共享服务器进程(服务端):
>alter system set shared_servers=25;//设置共享服务的进程数
>alter system set shared_server_sessions=100;//设置共享服务的用户数
>alter system set dispatchers='(protocol=tcp)(dispatchers=1)';//拿出一个进程作排号器,注意dispatchers参数加引号
设置共享服务器进程(客户端):
编缉tnsnames.ora将server=dedicated改为server=shared//将dispatchers注册到默认监听器。
用lsnrctl;services是否是dispatcher,约等5分钟才显示。dispatcher分配器。
对于共享服务器进程,当用户请求时,监听将不返回server process地址,而是返回dispatcher序列号。
以下操作不被共享服务器进程:管理、备份还原、装载、导入导出、并行。如shutdown immediate;
对于共享服务器进程,SGA要增,PGA(用户独有)要减。
/*存储结构-------------------------------------------------------------------------------------------------------------------------------------------------
查询表空间及文件:
>select tablespace_name,files from dba_data_files;
创建表空间:
>create tablespace tbs1 datafile '+DATA' size 20M;//若文件系统datafile的参数'/u01/app/oracle/oradata/orcl/tbs2.dbf'
>create tablespace tbs2 datafile '+DATA' size 20M,'+FRA' size 20M;//此命令创建2个数据文件,小表空间最多1024个文件,大表空间(32T-128T)只有1个数据文件
>create tablespace tbs3 datafile '+DATA' size 20M,autoextend on next 10M maxsize 10G,'+FRA' size 20M autoextend on next 5M maxsize unlimited;
删除表空间:
>drop tablespace tbs4;
EM图形界面管理表空间:略
段 区对应关系:
1M 64K
1-64M 1M
64M- 8M
区是最小的分配单位,块是最小的I/O单位。
数据由OMF管理的数据文件,在表空间删除会由oracle自动删除对应文件。????
删除表空间:
>drop tablespace tbs4 INCLUDING CONTENTS;
>show parameter db_create_file_dest;
>alter system set db_create_file_dest='/u01/app/oracle/oradata';
扩大数据库。
显示文件编号:
>select file# from v$datafile;
设置数据库文件大小:
>alter database datafile 9 resize 40M;
数据库文件大自动扩展:
>alter database datafile 10 autoextend on next 10M maxsize 10G;
表空间大小自动扩展:
>alter tablespace tbs3 add datafile '+DATA' size 10M autoextend on next 10M maxsize10G;
/*用户管理-------------------------------------------------------------------------------------------------------------------------------------------------
建帐户:
>create user jack identified by jack123;//需要SYSDBA权限,密码不加引号
系统权限。
用DCL语句(grant revoke)进行授予登录权限:
>grant create session to jack;
授予建表权限:
>grant create table to jack;
授予用户其它权限:
>grant create sequence,create synonym,create view to jack;
撤消权限:
>revoke create session from jack;
对象权限的撤消是级联的,系统权限的撤消是不级联的。
授予级联系统权限:
>grant create table to jack with admin option;
撤销级联系统权限:
>revoke create table from jack;
EM图形界面:Database-Users-填用户名,密码,系统权限
对象权限。对象权限为grant+权限+on表+to用户。
>grant select on hr.jobs to jack;
>revoke select on hr.jobs from jack;
>grant select on hr.jobs from jack with grant option;
>revoke select on hr.jobs from jack;//对象权限的撤销是级联的
级联???
>grant insert,update,delete on hr.jobs to jack;
角色使用:
>create role r1;
>grant select any table,create any table to r1;
>create role r2;
>grant all on hr.employees to r2;
>grant r1,r2 to jack;//把角色当作权限授权给用户
概要文件对应EM中的profile。用于资源控制和口令安全性。如:限制连接时间、空闲多长时间断开、每个用户限制的会话数。
EM中设置概要:Server-Security-Profiles-。
资源限制开启:
>alter system set
通过函数限制口令复杂度:要么用PL/SQL编。要么$ORACLE_OME/rdbms/admin/utlpwdmg.sql脚本,以SYS用户执行此脚本,就可以在"ComplexityFuntion"填入函数名。
配额:
alter user jack quota 20M on users;
alter user jack quota unlimited on example;
grant unlimited tablespace to jack;
/*并发访问-------------------------------------------------------------------------------------------------------------------------------------------------
复习:锁机制,行锁、表锁、事务锁。锁的并发性和兼容性。
事务结束释放行锁和表锁。
查看某用户的事务信息SID:
>select sid from v$session where username='HR';//注意用户名要大写。
获取事务SID的锁类型、锁级别、请求的锁、阻断时间(s):
>select sid,type,lmode,request,ctime from v$lock where type in ('TM','TX') and sid in(事务号1,事务号2);
3级锁较温和,6级是排它锁。
EM图形界面:Performance-BlockingSessions。
看书只看收集命令。教材学生指导书只有大纲的作用,写的不细致。
第七天
160721第七天OCP笔记
TM锁-DML enqueue
TX锁-Transaction enqueue
LMODE:
0 none
1 null
2 row-S(SS) RowShare
3 row-X(SX) RowExclusive
4 share(S)
5 share row exclusive(SRX)
6 exclusive(X)
锁的排他性:X锁全排他,RS锁除了X锁全兼容,RX锁、S锁、SRX锁只兼容RS锁,SRX锁、X锁自斥。
DML加RX锁,select for update加RS锁,DDL、DCL加X锁。锁的兼容会导致等待。
兼容的锁加锁后,一个会话解锁后只解其会话的锁。
用EM查看锁等待队列:Performance-InstanceLocks。
分别对第一个用户,第二个用户加锁:
>lock table jobs in row share mode;//能加上锁,说明二级锁是不排它的。
解锁:
>commit;
找到长期占有锁的会话:
>select sid,ctime from v$lock where block>=1;//查找超过1秒的阻断。
>select serial# from v$session where sid=上条命令进到的;
结束长期占有锁的会话:
>alter system kill session 填SerialNumber immediate;
死锁由Orcle自动撤销产生死锁的语句。
EM管理undo表空间:Server-AutomaticUndoManagement:
>create undo tablespace undotbs2 data '+DATA' autoextend on next 10M maxsize 10G;
Oracle只能用一个undo_tablespace,由此语句设置undo表空间:
>alter system set undo_tablespace='UNDOTBS1';
显示undo表空间的自动管理、保留时间、强制保留:
>show parameter undo_;//undo_retention在事务完成之后开始记时,
设置undo_retention:
>alter system set undo_retention=900;单位秒
从EM获取undo表空间设置建议:
RelatedLinks-AdvisorCenter指导中心-AutomaticUndoManagement-RunAnalysis计算保留时间与undo表空间大小的对应关系。
用as of timestamp(to_timestamp(时间))查询还原数据:
>select * from employees as of timestamp(to_timestamp('2016-07-13 11:00:00','yyyy-mm-dd hh24:mm:ss')) ;
/*数据库审计-----------------------------------------------------------------------------------------------------
审计包括:强制审计、sysdba审计、标准审计、FGA细粒度审计、基于值的审计。
授予用户sysdba权限:
>grant sysdba to hr;//
强制审计只审计管理员用户的登录行为。
查找强制性审计的进程号(由sid找paddr到spid):
>select spid from v$process where addr=(select paddr from v$session where sid=(select distinct sid from v$mystat));//注意v$process中的列名为addr
显示审计文件位置:
>show parameter audit_file_dest;//默认在$ORACLE_BASE/admin/orcl/adump;由上面的进程号找到审计文件位置
$进目录
$more orcl_ora_进程号.aud;
标准审记审计非sys用记的行为:
>show parameter audit_trail;
若audit_trail=DB则审计信息保存在数据字典aud$。若audit_trail=OS则审计信息存放在audit文件目录。
标准审计的具体内容:
审计范围-session(默认)、access
审计类型-默认成功失败都记录
审计用户-默认所有人
审计内空-执行语句、使用系统权限、使用对象权限。
启用审计:
>audit unlimited tablespace by hr;//启用无限表空间的审计
用表dba_auti_trail查询标准审计
>col obj_name for a10;
>select username,obj_name,action_name from dba_audit_trail where username='用户名HR' and obj_name='表名T1';
关闭审计:
>noaudit create sequence by hr;//关闭建序列的审计
审计的图形界面:Serer-Security-AuditSettings。
FGA细粒度审计,可以查看用户发出语句的详细信息。通过包DBS_FGA实现。
查文档:MasterBookList-PL/SQL Packages and Types Reference-DBMS_FGA。
语法如下:
DBMS_FGA.ADD_POLICY(
object_schema VARCHAR2,
object_name VARCHAR2,
policy_name VARCHAR2,
audit_condition VARCHAR2,
audit_column VARCHAR2,
handler_schema VARCHAR2,
handler_module VARCHAR2,
enable BOOLEAN,
statement_types VARCHAR2,
audit_trail BINARY_INTEGER IN DEFAULT,
audit_column_opts BINARY_INTEGER IN DEFAULT);
添加审计查看、修改50部门员工工资:
begin
DBMS_FGA.ADD_POLICY(
object_schema => 'hr',
object_name => 'employees',
policy_name => 'audit_50_sail',
audit_condition=> 'department_id=50',
audit_column => 'salary',
handler_schema => VARCHAR2,
handler_module => VARCHAR2,
enable => true,
statement_types=> 'select,update');
end;//注意包参数用=>,无效参数要去掉,end结尾加分号和/。
由数据字典查看dba_fga_audit_trail审计:
>select sql_text from dba_fga_audit_trail;
禁用审计:
DBMS_FGA.ADD_POLICY换为DBMS_FGA.DISABLE_POLICY
启用审计:
DBMS_FGA.ADD_POLICY换为DBMS_FGA.ENABLE_POLICY
删除审计:
DBMS_FGA.ADD_POLICY换为DBMS_FGA.DROP_POLICY
基于值的审计,可以看出值的变化。通过触发器记录信息,信息必需记录在自定义的表中。
sysdba审计。
开启sysdba审计:
>show parameter audit_sys_operations;
>alter system set audit_sys_operations=true scope=spfile;//此参数不能直接修改,需要重启数据库
>shutdown immediate;
>startup;
/*试用以下脚本不记录----------
scott.emp sal 的变化记录下来
create table audit_emp_change(name varchar2(10),oldsal number,newsal number,time date);
create or replace trigger tr_sal_change
after update of sal ON emp
for each row
declare
v_temp int;
begin
select count(*) into v_temp from audit_emp_change
where name=:old.ename;
if v_temp=0
then
insert into audit_emp_change values(:old.ename,:old.sal,:new.sal,sysdate);
else
update audit_emp_change set oldsal=:old.sal,newsal=:new.sal,time=sysdate
where name=:old.ename;
end if;
end;
/
/*----------
sysdba审计记录位置,再通过查进程号确定哪个文件:
>show parameter audit_file_dest;
/*数据库维护-----------------------------------------------------------------------------------------------------
由于sql语句处理成ExcutionPlans需要消耗系统资源。由优化程序统计信息可以获得较好的执行计划。
查询执行计划:
>set autotrace on;
>select sql_text,?? from v$sql;
由GATHER_DATABASE_STATUS Procedures包控制。
EM中查看统计信息:Server-QueryOptimizer-ManageOptimizerStatistics-GatherOptimizerStatistics。
由数据字典查看表的最后收集时间的表行数,用于优化执行计划。
>select num_rows,to_char(last_analyzed,'yyyy-mm-dd hh24:mm:ss') from dba_tables where owner='HR' and table_name='EMPLOYEES';
用GATHER_TABLE_STATUS Procedures包手动进行统计信息收集:
DBMS_STATS.GATHER_TABLE_STATS(
ownname=>'hr',
tabname=>'employees',
cascade=>true
第八天
160722第八天OCP笔记
性能管理:内存、I/O、应用程序(SQL PL/SQL)、资源争用(锁、闩、互斥Lock latch mutex)、网络
等待事件 v$event
查询等待事件:
>select distinct wait_class from v$event_name;
>select name from v$event_name;
查询等待事件(阻断)的SID:
>select sid from v$lock block=1;
等待事件相关的动态性能视图:系统v$sysstat v$system_event 会话v$sesstat v$session_event 特定服务v$service_stats v$service_event。从asktom.orale.com网站上找脚本。
内在优化由oracle 11g AMM Automatic Memiry Management自动管理。只需指定memory_target=内存大小,由MMAN进程通过AWR快照调整内存,每10分钟检测一次。
OLPT系统DB80%和OS20%,Oracle通过指导中心的内存指导报告内存。Oracle11g将sga_target设为0、pga_aggregate_target设为0(自动),只设置memory_target即可。
OLAP/DSS在线分析系统,即用作数据仓库时PGA大些 SGA50%/PGA50%。
验证索引对性能提升:
设置跟踪:
>set autotrace on;//需要SYSDBA权限
>create table hr.test200 tablespace users as select * from dba_objects;//建表
>create index hr.ind_test200 on hr.test200(object_id);//建索引
执行查询:
>select * from hr.test200 where object_id=1000;
将表移动,将使索引失效:
>alter table hr.test200 move tablespace example;
查索引是否失效:
>select status from dba_indexes where owner='HR' and index_name='IND_TEST200';
解决只需重建索引:
>alter index hr.ind_test200 rebuild;
删除索引:
>drop index hr.ind_test200;
/*备份恢复的概念---------------------------------------------------------------------
故障现象:语句失败、用户进程失败、网络故障、用户错误、实例故障、介质故障。只有介质故障通过"备份和恢复"。
复用文件一般3个,太多影响性能。控制文件、日志文件、归档日志可以复用,数据文件不复用。全数据库、数据文件、归档日志、控制文件、参数文件可以备份。
复用控制文件:
>select name from v$controlfile;//查看现有控制文件
>asmcmd拷贝控制文件(注意需要关闭文件进行控制文件拷贝,否则容易出现数据库版本不一致)
>alter system set control_files='控制文件1','控制文件2','控制文件3' scope=spfile;//注意ASM存储中.后面的文件名不填。control_files只能改参数文件
注意:控制文件挂多个只是方便查询复用的位置,而只有一个生效。
>重启数据库
ASM中拷贝文件:
$su - grid
$asmcmd
>cd;ls进目录
>cp 被拷文件 拷贝到
ASM常用命令:cd ..进入根目录,lsdg列出磁盘组,lsdsk列出磁盘。
复用日志文件:
>col member for a50;
>select group#,member from v$logfile;
>alter database add logfile member '+DG' to group 1;//文件系统填路径
>alter database add logfile member '+DG' to group 2;
>alter database add logfile member '+DG' to group 3;
切进日志直到消除invalid状态:
>alter system switch logfile;
>select group#,member,status from v$logfile;
复用归档日志(归档日志是组内镜像,组间同步)。
设置归档路径:
$mkdir -p /u01/arch01;
$mkdir -p /u01/arch02;
>alter system set log_archive_dest_1='location=/u01/arch01';//ASM为'location=+FRA'
查看归档路径:
>show parameter log_archive_dest;//显示归档路径
>show parameter db_recovery_file_dest;//默认归档路径
>关数据库,再启到mount模式startup mount
开启归档:
>alter database archivelog;
#ps -ef|grep ora_arc;//查看进程
检查归档开启:
>desc v$database;//找到log_mode
>select log_mode from v$database;
备份工具RecoveryManager可用于在线备份。
数据库必需先归档后备份,归档过程为:建目录,设置归档路径(检查设置),在数据库挂载状态开启归档(检查进程),切换以使用归档。
先删除表空间方便实验:
>drop tablespace 表空间名;
>drop datafile 文件名
$su - oracle
$rman target /
备份全数据库:
>backup database;
备份表空间:
>col tablespace_name for a30;
>select tablespace_name,file_name,file_id from dba_data_files;
>backup tablespace users,example;
备份数据文件:
>backup datafile 4,5 format '/u01/backup/f4_5.bak';
备份控制文件:
>backup current controlfile;
备份参数文件:
backup spfile;
备份归档日志
backup archivelog all;
查文档:backup & recovery;backup & recovery user guides
控制文件坏了只能启动到实例。
查控制文件目录:
>select name from v$controlfile;
$关闭数据库,删除控制文件,再启动数据库;ASM存储需要先关闭数据库才能删除控制文件
运行一条语句,再查日志找到控制文件的报告:
$tail -20 $ORACLE_BASE/diag/rdbms/orcl/orcl/trace/alert_orcl.log;
设置control_files修复:
>alter system set control_files=没坏的文件;
也可以拷贝修复:
$关闭数据库,拷贝控制文件,再重启数据库。
注意:ASM会删除空目录,是OMF的特征。建目录mkdir +FRA/orcl/controlfile/。
日志文件损坏修复。日志文件只添加无需拷贝。
先切换日志以启用日志:
>alter system switch logfile;//切换日志去掉INVALIDATE
>select group#,member,status from v$logfile;
>删除部分日志文件模拟损坏,ASM需要关闭数据库才能删除文件,查看预警日志文件。
$tail -20 $ORACLE_BASE/diag/rdbms//orcl/orcl/trace/alert_orcl.log;
通过删除损坏的日志组成员来修复:
>alter database drop logfile member '日志文件路径';
若无法删除,说明为当前日志组成员,使用alter system switch logfile;切换掉。
重加日志组成员,还原复用结构:
>alter database add logfile member '日志文件路径' to group 组号;
临时文件损坏。临时文件用于存放临时表和磁盘排序。
查临时文件位置:
>select name from v$tempfile;
查临时表空间名:
>select tablespace_name from dba_tablespaces where contents='TEMPORARY';
删除临时文件模拟损坏:ASM删除文件需要关闭数据库
添加临时文件:
>alter tablespace temp add tempfile '$ORACLE_BASE/oradata/orcl/tmp02.db' size 20M autoextend on next 20M maxsize 10G;//注意不要漏掉容量
删除损坏文件:
>alter tablespace temp drop tempfile '$ORACLE_BASE/oradata/orcl/tmp01.db';
若在关闭期间损坏临时表空间文件,则数据库自动重建。
口令文件的损坏,口令损坏将导致远程登录无法使用。
删除口令文件:
$rm $ORACLE_HOME/dbs/orapworcl;
重建口令文件:
$orapwd file=$ORACLE_HOME/dbs/orapworcl password=oracle;
数据文件损坏(非关键数据USERS)。
>alter system flush buffer_cache;
>select tablespace_name,file_name,file_id from dba_data_files;
查看备份文件:
$rman
RMAN>list backup;
损坏文件离线:
RMAN>sql 'alter database datafile 4,5 offline';
还原文件:
RMAN>restore datafile 4,5;
恢复文件(跑日志):
RMAN>recover datafile 4,5;
文件上线:
RMAN>sql 'alter database datafile 4,5 online';
数据文件损坏(关键数据SYSTEM/SYSAUX),需要关闭数据库进行恢复。
RMAN>run{
startup mount;
restore datafile 1,2,3,4,5;
recover datafile 1,2,3,4,5;
alter database open;
}
5、丢失所有日志组成员(上节课讲过丢失部分日志组成员)
INACTIVE非当前(已写回磁盘的日志,做日志恢复操作无需该组操作) ACTIVE非当前(此组日志对应的数据没有完全被刷新回磁盘,做数据库恢复需要该组中的日志信息) CURRENT(当前正在被使用的日志组)
先查看日志组成员:
>select group#,sequence#,status from v$log;
切换日志:
>alter system switch archivelog;
执行检查点,将所有日志对应的数据写回磁盘:(全部成为INACTIVE)
>alter system checkpoint;
破坏:删除INACTIVE的日志文件:
INACTIVE日志修复,不丢失数据,修复方法为:
>alter database clear logfile group 2;
第九天
160723第九天OCP笔记
参数文件的损坏。参数文件损坏将无法启动和写参数,已运行数据库可以使用。
指定文件备份路径:
>backup spfile format '/u01/sp.bak';
>list backup;
破坏参数文件:
$rm $ORACLE_HOME/dbs/spfileorcl.ora;//ASM的控制文件在+DATA/orcl/spfileorcl.ora
关闭数据库:
>shutdown immediate;
RMAN的数据库服务器至少到开启至实例状态,而缺少参数文件将无法启动至实例状态。解决办法是用RMAN内置实例启动数据库:
RMAN>start nomount;
用RMAN修复:
RMAN>restore spfile from 'u01/sp.bak';
RMAN中重启数据库:
RMAN>startup force;同startup abort+startup;
常见问题:若出现NO LOGON,是由于关闭时间过长,可以结束进程强制关闭数据库。
RMAN的设置。
查看所有的配置项:
RMAN>show all;
修改参数:
RMAN>参数;
删除备份:
RMAN>delete backup;不能在ASM中删除否则将不能同步日志,RMAN会误认为备份存在
备份参数有:控制文件自动备份、备份冗余、优化、加密、类型。
RMAN中只用分号查询命令帮助。查文档
configure control file auto backup启用控制文件自动备份。
configure retention policy to redundency 1备份冗余量,1为保留最近一次冗余量,2为保留最近两次冗余量。
configure retention policy to recovery window of 7 days备份保留天数。
cofigure backup optimization on备份优化以节约磁盘(恢复时间更长),一般不开。
configure encryption for database off开启加密。
configure encryption algorithm 'AES128'开启加密算法。
configure device type disk paralielism 1 backup type to backset备份类型:backup set备份集即空块不备份、image copy拷贝即和原始文件一样。
>backup database;
>backup as backupset database;
>backup as compressed backupset database;
>backup as copy database;
完全备份backup database,增量备份backup incremantal level 0 database。增量备份从0级开始。累积增量备份backup incremental level 1 cumulative database;
>delete backup;
>delete copy;
恢复控制文件数据库。
非本机登录RMAN:
$rman target sys/oracle@orcl;
备份共备份了:备份数据和备份原数据。备份原数据在控制文件当中。
通常建立目录数据库建立备份元数据-catalog database。丢失全部控制文件时就需要用catlog。
建立catlog过程:建库、建表空间、建用户、授权、创建catlog、注册catlog、同步catlog。
#xhost +
#su - oracle
$export $ORACLE_SID=catdb;
$dbca;不需要EM、不用自动管理、存储用文件系统、字符集AL32UTF8。(建库dbca时会自动在tnsnames.ora建立网络服务名)
>show parameter db_name;
建表空间用于存放元数据:
>create tablespace cats datafile '$ORACLE_BASE/oradata/catdb/cats.dbf' size 20M autoextend on;
建一个帐户用于管理元数据:
>create user catu identified by "catu" default tablespace cats temporary tablespace temp quota unlimited on cats;
授权:
>grant connect,resource,recovery_catalog_owner to catu;
创建catlog:
$rman target / catalog catu/catu@catdb
$rman target sys/oracle@orcl catalog catu/catu@catdb;//命令含义同上条
RMAN>create catalog;
注册catlog:
RMAN>register database;(否则将出现target database not found错误)
rman target /的备份同步到catlog:
>resync catalog;
修改之前的笔记,在grid帐户下配监听。
数据库的不完全恢复:主动/被动。
1、基于时间点的数据库不完全恢复。例如对DDL语句的恢复。
查看备份:>report need backup;//查看现有备份
$export NLS_LANG=american_america
$export NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'
$rman target /
RMAN>run {
startup force mount;//恢复需要在mount模式下进行
set util time='2016-07-20 01:36:00';
restore database;
recover database;
alter database open resetlogs;//数据库恢复之后必需以重置日志的方式打开一次
}
查看日志序号:
>archive log list;
删除之前日志:
>delete noprompt backup;
>delete noprompt copy;
进行第一次增量备份
>backup incremental level 0 database;
设置:
>sql 'alter system archive log current';
同步catalog:
>resync catalog;
2、使用SCN号进行数据恢复:
查SCN号:
>select current_scn from v$database;
恢复:
RMAN>run {
startup force mount;//恢复需要在mount模式下进行
set util scn=填SCN号;
restore database;
recover database;
alter database open resetlogs;//数据库恢复之后必需以重置日志的方式打开一次
}
3、基于SEQUENCE日志序号的数据恢复。
日志归档要复用,且放在不同磁盘上:
备份:
>delete noprompt backup;
>delete noprompt copy;
>archive log list;
>backup incremental level 0 database;
>sql 'alter system archive log current';
>resync catalog;
查日志的序号:
>desc v$log;
>select group#,sequence#,status from v$log;//序号为current为当前,
先进行表的添行DML语句,再切日志以增加日志序号:
>alter system switch logfile;
恢复:
RMAN>run {
startup force mount;
set util sequence=6;//恢复到第5组日志
restore database;
recover database;
alter database open resetlogs;
}
4、所有控制文件损坏:
备份:
>delete noprompt backup;
>delete noprompt copy;
>archive log list;
>backup incremental level 0 database;
>sql 'alter system archive log current';??含义
>resync catalog;
查看目前控制文件:
>select name from v$controlfile;
>shutdown abort;
>删除控制文件
启动到nomount并用RMAN进行恢复:
>startup nomount;
RMAN>configure control file auto backup;
RMAN>restore controlfile from autobackup;
RMAN>alter database mount;
RMAN>recover database;//文件不同步,仍要进行recover
RMAN>alter database open resetlogs;
再进行数据库备份:
5、
>select group#,sequence#,status from v$log;
>create table test100(id int);
>insert into test100 values(1);
>commit;
>alter system switch logfile;
>insert into test100 values(2);
>commit;
>alter system switch logfile;
>select group#,sequence#,status from v$log;
rman target / catalog catu/catu@catdb
startup mount;
restore database;
recover database until cancel;参数AUTO
recover database until cancel;参数CANCEL
alter database open resetlogs;
第十天
160724第十天OCP笔记
备份脚本:
run{
>delete noprompt backup;
>delete noprompt copy;
>archive log list;
>backup incremental level 0 database;
>sql 'alter system archive log current';
>resync catalog;
}
&灾难恢复。灾难恢复不含跟踪文件、预警文件、口令文件。
日常维护--
RMAN中启用控制文件自动备份configure control file auto backup
建立catalog
检查备份--
$rman target / catalog catu/catu@catdb
RMAN>list backup;
检查备份内容是否好:
RMAN>crosscheck backup;
破坏--
用联合查询查出控制文件、数据文件、日志文件:
>select name from v$datafile union select name from v$tempfile union select name from v$controlfile union select member from v$logfile;
>关闭数据库
asmcmd>删除以上文件
查参数文件并删除:
asmcmd>rm +DATA/orcl/spfileorcl.ora
查口令文件并删除:
$rm $ORACLE_BASE/dbs/orapworcl;
恢复--
恢复顺序:参数文件、控制文件、数据日志文件、口令文件。
文件损坏只参启到实例:
RMAN>startup nomount;//注意文件未损坏,要删除。否则会调用错误的参数文件而无法恢复
恢复参数文件:
RMAN>restore spfile from autobackup;//默认备份目录+FRA/ORCL/AUTOBACKUP/以日期命名的目录/。若无法恢复则用完全路径
RMAN>shutdown immediate;
RMAN>startup nomount;
恢复控制文件后可以挂载启动:
RMAN>restore controlfile from autobackup;
RMAN>shutdown immediate;
RMAN>startup mount;
恢复数据文件:
RMAN>restore database;
SQL>recover database until cancel using backup controlfile;//。注意恢复日志文件的跑日志要在SQLPlus中,填参数为先AUTO、后CANCEL。???
恢复日志和临时文件:
SQL>alter database open resetlogs;//也可以在RMAN中执行
创建口令文件:
$orapwd file=%ORACLE_HOME/dbs/orapworcl password=oracle;
删除备份并重新备份:
&灾难恢复需要换设备,不能恢复到原始设备上的问题处理。
建目录:
$mkdir -p /u01/app/oracle/oradata/bak/;
查文件位置:
>select name from v$datafile;
确认备份:
RMAN>list backup;
恢复脚本:(添加了set newname,switch datafile)
run{
sql 'alter database datafile 4,5 offline';
startup mount;
set newname for datafile 4 to '/u01/app/oracle/oradata/bak/users01.dbf';//项ASM磁盘组则换为'+DG',DG为换上的新磁盘组。
set newname for datafile 5 to '/u01/app/oracle/oradata/bak/examples01.dbf';
restore datafile 4,5;
switch datafile 4;
switch datafile 5;
recover datafile 4,5;
sql 'alter database datafile 4,5 online';
}
&ASM的迁移。
创建一个非ASM的表空间--
$mkdir -p $ORACLE_BASE/oradata/orcl/
>create tablespace tbs10 datafile '/u01/app/oracle/oradata/orcl/tbs10.dbf' size 20M autoextend on;
>create table sys.test10 tablespace tbs10 as select * from dba_objects;
>select name,file# from v$datafile;
将非ASM表空间迁移到ASM--
查看未备份项:
RMAN>report need backup;
拷贝备份到指定磁盘组:
RMAN>backup as copy datafile 6 format '+DATA';
RMAN>sql 'alter database datafile 6 offline';
切换文件名:
RMAN>switch datafile 6 to copy;//迁移地址可以简写为copy
由于操作延迟,将文件前滚一点:
RMAN>recover datafile 6;
RMAN>sql 'alter database datafile 6 online';
&Blobk块的损坏。
开启校验
物理校验db_block_checksum=TYPICAL 耗CPU2~3%
逻辑校验db_block_checking=MEDIUM 耗CPU1-10%
物理校验在块头写入校验信息,逻辑校验校验段头块和段之间的关系。校验只能预防坏块。
文档
创建表空间tbs20并加表test20--
查看表的块信息:
>select header_file,header_block,blocks from dba_segments where segment_name='TEST20' and owner='HR';
备份--
RMAN>report need backup;
RMAN>backup datafile 7;//7是新建的表空间对应文件
破坏块--
#dd dd of=/u01/app/oracle/oradata/orcl/tbs20.dbf bs=8192 conv=notrunc seek=200<
>任意填覆盖信息
>EOF;//结束
制造查询出错,报错为第一个坏块--
>alter system flush buffer_cache;
>exit;
$sqlplus hr/hr
>select count(*) from sys.test20;
修复坏块--
#su - oracle
找到所有坏块:
$dbv file=$ORACLE_BASE/oradata/orcl/tbs20.dbf blocksize=8192;
用RMAN修复坏块:
RMAN>recover datafile 7 block 坏块序号用逗号隔开;
附dd命令:
将指定的文件写入到指定的输出文件:
#dd if=boot.bin of=orange.img bs=512 count=1 conv=notrunc;
&Oracle11g新特性DRA Database Recovery Advisor数据恢复顾问
使用DRA用来修复坏块--
发现错误:
RMAN>list failure detail;
修复建议:
RMAN>advice failure 错误号;
修复错误:
RMAN>repair failure;
&闪回技术
闪回删除 回收站
闪回查询 UNDO表空间
闪回事务 redo log
闪回数据库 数据库的闪回日志
Tocal Recall 闪回归档
1、闪回删除
drop table并没有删除而是放到回收站。每个表空间有独立的回收站,除了SYSTEM表空间。
开启回收站:
>show parameter recyclebin
>alter system set recyclebin on;
实验--
>create table hr.t1 tablespace system as select * from dba_objects where rownum<10001;
>create table hr.t2 tablespace system as select * from dba_objects where rownum<10001;
>c/2/3;把2换成3再创建张表
>create index hr.idx_t1 on hr.t1(object_id) tablespace system;
>create index hr.idx_t2 on hr.t1(object_id) tablespace system;
>create index hr.idx_t3 on hr.t1(object_id) tablespace system;
>drop table hr.t1;//删除表会自动删除索引
>drop table hr.t2;
>drop index hr.inx_t3;
>drop table hr.t3;
显示回收站内容:
>show recyclebin;
加收站中的名称较长,用数据字典查其原名user_recyclebin或dba_recycle_bin:
>select object_name,original_name,type from user_recyclebin;
回收站中的数据可以查询SELECT,而不可以DML/DDL操作。表的删除其索引也被附带删除。
闪回:
>flashback table t2 to before drop;(闪回表的相关索引同时闪回)
若回收站中有重名,需使用回收站中的名称,需用双引号界定,并重命名:
>flashback table "回收站中的名称" to before drop rename to t2_other;
以下两种情况表删除不经过回收站:drop table t1 purge;、表经过virtual personal database(VPD)加密。
当有空间压力时,回收站中的内容会自动清空。自动扩展的表空间有空间压力也要先清空回收站。
>purge table t2;
>purge index t1_idx;
清空回收站:
>purge user_recycle_bin;purge dba_recycle_bin;
>purge tablespace users USER hr;
2、闪回查询
undo_tablespace=undotbs1;
undo_management=auto;
undo_retention=900;
用于已提交DML的闪回查询。
>select salary from employees where employee_id=196;
>update employees set salary=13100 where employee_id=196;
>commit;
闪回查询:
>select salary from employees as of timestamp(to_timestamp('2016-07-20 01:00:00','YYYY-MM-DD HH24:MI:SS')) where employee_id=196;
用子查询查闪回值:
>update employees set salary=(select salary from employees as of timestamp(to_timestamp('2016-07-20 01:00:00','YYYY-MM-DD HH24:MI:SS')) where employee_id=196) where employee_id=196;
将表闪回到过去的时间点:
>alter table employees row movement;//开启行迁移功能
>flashback table employees to timestamp(to_timestamp('2016-07-20 01:00:00','YYYY-MM-DD HH24:MI:SS'));
通过伪列(versions_starttime versions_endtime)看列具体的时间:
>select salary,versions_starttime,versions_endtime from employees versions BETWEEN to_timestamp('2016-07-20 01:00:00','YYYY-MM-DD HH24:MI:SS') AND to_timestamp('2016-07-20 02:00:00','YYYY-MM-DD HH24:MI:SS') where employee_id=196;
3、闪回事务 Redo Log
开启补充日志:
>alter database add supplemental log data;
>alter database add supplemental log data(primary key) columns;//需要SYSDBA权限
DML:
>update hr.employees set salary=8100 where employees_id=196;
查看闪回事务:
>select undo_sql from flashback_saction_query where table_name='EMPLOYEES' and TABLE_OWNER='HR';//需要SYSDBA权限
>update "HR" ."EMPLOYEES" set "SALARY"='6100' where rowid='闪回事务的rowid';
4、闪回数据库--数据库闪回日志
前提要先启用归档模式
>shutdown immediate;
>startup mount;
启用数据库闪回功能:
>alter database flash on;
检查已开启闪回功能:
>select flashback_on from v$database;
#ps -ef|grep ora_rvwr
查看闪回日志位置:
>show parameter db_recover_file_dest;
设置闪回日志保留时间:
>alter system set db_flashback_retention_target;
误操作truncate table的解决:
RMAN>startup force mount;
RMAN>flahsback database to time="to_date('2016-07-20 11:57:00','YYYY-MM-DD HH24:MI:SS')";//注意time时间赋值加引号
RMAN>alter database open resetlogs;
RMAN>flahsback database to SCN=值;
RMAN>flahsback database to SEQUENCE=值;
用还原点还原--
>create restore point aaa;
>truncate table hr.t2;
>starup force mount;
>flashback database to restore point aaa;
>alter database open resetlogs;
闪回的限制:
1、控制文件重新建立过或者还原过:
2、删除过表空间;
3、收缩过数据文件;
这些情况只能数据库的不完全恢复来解决。
5、闪回归档Total Recal,用于闪回查询的UNDO表空间限制undo_retention
>create tablespace recall datafile '+DATA' size 20M autoextend on;
>create flashback archive default flash_recall tablespace recall retention 10 year;
>alter table hr.employees flashback archive flash_recall; select salary from employees as of timestamp(to_timestamp('2016-07-20 10:44:29','yyyy-mm-dd hh24:mi:ss'));
第十一天
160727第十一天OCP笔记
移动数据(Oracle的IO)--
非Oracle数据移到Oracle数据 用装载SQL Loader
Oracle数据移到Oracle数据 用导入导出DataDump
外部表技术:将数据旋转在数据库外部,通过数据库访问外部数据。分为非Oracle数据外部表,和Oracle数据外部表。
官方文档
//****************************************************************************************************
&SQL Loader使用--
TXT/EXCEL/SQL Server/。。
编缉数据文件:
$vim f1.dat
101,M,zhao
102,M,qian
103,F,sun
编缉控制文件(导入语法):载入文件、文件导入的表符列。
$vim f1.ctl
load data infile 'f1.dat'
insert into table students WHEN (5)=M fields terminated by ','
TAILING NULLCOLS
(stu_id,stu_sex,stu_name)
其中fields指字段。每行就是数据库行的分隔符,不用指定。
INSERT|APPEND|TRUNCATE关键字,INSERT只能向空表加入、APPEND追加、TRUNCATE先清空后添加。
WHEN (5)=M第五个字符为M的行放弃数据,第一个字符为1。未装载数据分为放弃数据和拒绝数据。
建表:
>create table students (stu_id number(3),stu_sex char(1),stu_name varchar2(10))
装载:
$sqlldr hr/hr control=f1.ctl;//需要指定向哪个用户装载数据
$sqlldr hr/hr control=f1.ctl log=f1.log bad=f1.bad;//功能同上条语句
产生f1.log存导入记录,f1.bad存未导入的记录。
对表添加约束(功能同放弃数据):
>alter table students add constraint ck_name CHECK(stu_id not in('qian'));
&装软件包使SQLPlus能够翻命令:解包、配置、编译、安装、加别名
#tar zxf rlwrap-0.36.tar.gz
#./configure
#make
#make install
#echo "alias sqlplus='rlwrap sqlplus'">>/home/oracle/.bashrc;//两个剑头指追加
#echo "alias rman='rlwrap rman'">>/home/oracle/.bashrc
查命令历史:#history
//****************************************************************************************************
&DataPump使用--
命令 expdp和impdp
数据包dbms_datapump
创建目录对象:
>create directory dump as '/u01/app/oracle/dump/';//目录由oracle帐户创建,命令需要SYSDBA权限
>grant read,write on directory dump to hr,system,scott,sh;
导出表:
$expdp hr/hr directory=dump dumpfile=employees.dmp tables=employees,departments;
导出schema的所有表:
$expdp hr/hr directory=dump dumpfile=employees.dmp schema=hr;
导出tablespace:
$expdp \'sys/oracle as sysdba\' directory=dump dumpfile=employees.dmp tablespaces=users,examples;//需要SYSDBA权限
导出db:
$expdp \'sys/oracle as sysdba\' directory=dump dumpfile=employees.dmp full=y;
参数文件1,含directory、dumpfile参数:
$vim 02.par
directory=dump
dumpfile=hr02.dmp
schemas=hr
exclude=table:"in ('jobs','locations')"
参数文件2,导出部分表:
$expdp scott/tiger directory=dump dumpfile=scott.emp parfile=/tmp/01.par
$vim 01.par;//用参数文件
schemas=scott
include=table
include=package
include=view:"LIKE 'V0%'"
参数文件3,只导出查询结果:
schemas=hr
tables=employees
query=employees:"where salary>15000"
参数文件4,导出表的采样:
tables=employees
sample=40
参数文件5,导出元数据或只导出数据:
tables=employees
content=metadata_only|data_only|all
导入表:
>create table emp01 as select * from employees;//建表
$expdp hr/hr directory=dump dumpfile=emp01.dmp tables=emp01;//导出表
>drop table emp01;//删除表
$impdp hr/hr directory=dump dumpfile=emp01.dmp tables=emp01;//导入表
>select * from emp01;//查询是否导入
只导入数据而不导入元数据:
$impdp hr/hr directory=dump dumpfile=emp01.dmp tables=emp01 content=data_only;
追加|清空方式导入:
$impdp hr/hr directory=dump dumpfile=emp01.dmp tables=emp01 table_exists_action=append|truncate;//导入表
将表映射导入到其它帐户:
$expdp scott/tiger directory=dump dumpfile=emp01.dmp tables=hr.emp01 schemas_map=hr:scott;
$impdp scott/tiger directory=dump dumpfile=emp01.dmp tables=hr.emp01 schemas_map=hr:scott remap_tablespace=example:users;//如果映射到的帐户没有表空间,则创建
//****************************************************************************************************
&数据放在Oracle外,外部表只能查不能改--
非Oracle到Oracle 装载数据驱动 ORACLE LOADER Access Driver
create table students_e (stu_id number(3),stu_sex char(1),stu_name varchar2(10))
organization external
(type oracle_loader
default directory dump
access parameters (records delimited by newline fields terminated by ',' missing fields values are null)
location ('f1.dat'));
外部只能查询,不能做索引,也不能DML操作。由于外部表的性能较低,只用于偶尔的查询。
&Oracle到Oracle的访问,即直接访问其它数据库而不用导入数据--
数据泵驱动 ORACLE DATAPUMP Access Driver
方法共3步。
从orcl导出hr.employees--
CREATE TABLE students_e (stu_id,stu_sex,stu_name)
organization external
(type oracle_loader
default directory dump
location ('employees.dmp'))
AS SELECT employee_id,last_name,salary FROM employees where salary>10000
copy到目标数据库所有机器--
接收的catdb数据库也需要创建目录对象和授权:
本地或网络拷贝到目标机器的目录对象:
在目标catdb建外部表,读取该文件:
CREATE TABLE students_e (stu_id number,stu_sex char(1),stu_name varchar2(10))
organization external
(type oracle_loader
default directory dump
location ('employees.dmp'))
//****************************************************************************************************
内存管理
6大池除了log_buffer均为自动设置。
6大池之外的保留缓冲池db_keep_cache_size、循还缓冲池db_recycle_cache_size、nK缓冲区调整缓存db_nK_cache_size基中n为2、4、8、16、32。
块大小db_block_size,根据行大小设置块大小,1块中保存多行。
保留缓冲池重用机率很高,循还缓冲池重用机率很低。
高重用的表缓冲到保留缓冲池:
>alter table hr.employees storage (buffer_pool recycle);
转存到默认缓冲池:
>alter table hr.employees storage (buffer_pool default);
>alter system set db_16k_cache_size=16M;
>create tablespace tbs16 datafile '+DATA' size 20M autoextend on blocksize 16k;
表空间块大小一般与buffer_cache块大小一致,不同则先转到db_nK_cache_size缓冲,再转到buffer_cache。表空间的行尽量放在不同块中,目的是提高并发量。
db_nK_cache_size设置小,全表扫描慢而并发访问变块。
查看各池容量:
>select component,current_size from v$sga_dynamic_components;
sga_target
pga_aggregate_target
memory_target
memory_max_target
共享池分为:library cache、row cache、result cache结果缓存(存储已查询结果,一般不开启,需配合参数文件开启)、
若做成共享服务器,则原本在PGA中的UGA(用户全局区)会移动到SGA的大型池中。
>select name,value from v$sysstat where name='physical reads';//查物理读
>select name,value from v$sysstat where name='consistent gets';//查一致性读
>select name,value from v$sysstat where name='db block gets';//查当前读
命中率:1-物理读/(一致性读+当前读),命中率高而性能未必高。
AWR report查看命中率报告:
Performance-AWR Baselines
第十二天
160728第十二天OCP笔记
医院建立信息数据库,收集健康设备的信息。
OLPT系统调优的首要原则就是绑定变量。
使用绑定变量避免硬解析:
var v1 number
exec :v1:=196
select salary from employees where employee_id=:v1;
PL/SQL的变量、赋值号加冒号。
让Oracle自动替换成绑定变量:
>alter system set cursor_sharing=force;//force的引号可加可不加
查询执行次数、解析次数:
>select executions,parse_calls from v$sqlarea where sql_text like '语句';//需要SYSDBA权限,也可以用表v$sql
SEQUENCE对于单实例数据库cache 100。多实例RAC数据库cache 5000。
pin住PL/SQL对象
自动共享内存管理。MMIN收集工作量为信息基础,MMAN调整内存。白天为OLPT在线查询系统,晚上为OLAP在线分析系统。
由AMF实现,配合spfile实现。早期版本的Oracle用init初始化参数,缺点是参数不能被系统修改。
性能优化方法:
规划:投资、系统(可扩展性Linux最强)...
SQL优化(应用优化) 对应课程SQL turning 调整:SQL PL/SQL
性能优化(实例优化)对应课程Performance Turning 调整:内存、I/O、网络、资源如lock
v$sys_time_model系统时间模型 v$sess_time_model会话时间模型。用于查询数据库启动、SQL解析、SQL执行、SQL编译等时间的消耗。
生成AWR报告:
@?/rdbms/admin/awrrpt.sql
报告保存在/home/oracle/
用EM查看资源的会话消耗:
EM-Performance-TopCustomers-TopSessions
/****************************************************************************************************
???
SQL优化指导 STA sql tuning advisor
Automatic SQL Tuning Result
SQL访问指导 SAA sql access advisor
SQL性能分析 SPA sql performance analyzer 位置:EM-Server-AdvisorCentral-sql performance analyzer
自动化任务 EM-Server-Automatic-AutomaticSqlTuning
EM-Server-AdvisorCentral-
优化指导:个别语句用Automatic SQL Tuning Result优化、使用SQL Profile直接修改执行计划、收集统计信息、使用索引、修改SQL语句。后3条都是间接干涉执行计划。
第十三天
160729第十三天OCP笔记
江苏移动外包:
限制job资源使用:
PLAN--group??
EM-Server-OracleScheduler-Window
CreateWindow-Name:DayWindow-Repeat:by days-duration:12h
CreateWindow-Name:DayWindow-Repeat:by days-duration:12h
>ater system set resource_manager_plan;
&管理空间。
OMF管理数据文件/控制文件的参数:db_create_file_dest=+DATA
日志文件/控制文件:db_create_online_log_dest
块--
块大小db_block_size。块大小优先由表空间blocksize决定,未指定则由db_block_size决定。
块预留10%的pct free空间,仅用于更新数据UPDATE。块的pct free用完就需要行迁移了。
块空闲空间按剩余空间分类:fs1<25% ,25%
空表不占空间,只是在数据字典中留记录。
数据录入是无序的,进行表的整理可以提高全表扫描的性能。
行链接:行大于块大小。行迁移:update的新数据大于旧数据且块pct free用完,将旧块指向新块的地址。
避免行链接的方法:
>alter system set db_16k_cache_size=16M;
>create tablespace tbs16 datafile '+DATA' size 20M autoextend on blocksize 16k;
解决行迁移:
使用段指导发现行迁移并解决。可以添加自动化任务定期解决。
手工处理行迁移--
>create table scott.t1 (id number,name varchar2(2000));
begin
for i in loop 1..1000
insert into scott.t1 values(i,'aa');
end loop;
commit;
end;
/
>update scott.t1 set name=lpad('x',1550,'x') where mod(id,2)=1;//语法lpad(列名,长度,填充符)
查具有行移的表:
>@?/rdbms/admin/utlchain.sql;
>analyze table scott.t1 list chained rows;
拷出来(拷出具有行迁移的行):
>create table t1_chain as select * from scott.t1 where rowid in(select head_rowid from chained_rows);
清空表:
>select count(*) from scott.t1_chain;//查下迁移行数量
>delete scott.t1 where rowid in(select head_rowid from chained_rows);
再拷回去:
>insert into scott.t1 select * from scott.t1_chain;
区的管理--
extent management local
segment space management auto|manual
段的延迟创建(创建表时并不分配空间,插入时创建):
>alter system set deferred_segment_createion=true;
Oracle在安装时会创建很多永远不会用到的空表,段延迟创建可以节约空间和加快安装速度。
段的立刻创建:
>create table t1 segment creation immediate as select * from t2 where 1=2;
按需创建表只适用于非分区表和索引,不适用于IOT、聚簇表...,不适用于字典管理的表空间中的表。
先创建索引逻辑不使用,以后使用:
>create index t1_idx on t1(id) unusable;
>alter index t1_idx rebuild;
表压缩减少IO多耗CPU,BASIC压缩方式适用于OLAP/DSS数据仓库,FOR OLTP压缩方式适用于OLTP常规交易型数据库。
>create table t1 compress basic|for olpt|nocompress;
收缩段的3步:
>alter table t2 enable row movement;
移动行 进行块的整理:
>alter table t2 shrink space compact;
降低高水位HWM 释放空间:
alter table t2 shrink space;
如果只执行第3步,不执行第2步,则在收缩段期间不能进行DML语句。
收缩段的优点是节约空间,提高全表扫描性能。
管理可恢复的空间分配--
会话交互(会话遇到空间问题,等待问题解决而非终止):
>alter session enable resumable;
系统级别可以设置会话时间,超时由系统选择:
>show parameter resu
>alter system set resumable_timeout=3600;//单位:秒
目前磁盘为4K扇区,Linux内核3.0以上支持4K扇区磁盘。要求db_block_size要4K~32K,默认8K。32以上需要OS支持。
查看日志的块大小:
>select blocksize from v$logfile
建库时要设置日志组块大小16K,提高性能。
移动表空间,对于使用不同指令集的CPU,需要用RMAN提供的convert命令。--
过程:表只读、datadump导出metadata、转字节码、拷元数据及数据文件、datadump导入、表读写。
建表:
>create tablespace test datafile '+DATA' size 10M;
1、在orcl数据库将表空间置为read only:
>alter tablespace test read only;
2、使用datadump提取表空间的metadata为一个文件:
>create directory dump as '/u01/app/oracle/dump/';//目录由oracle帐户创建,命令需要SYSDBA权限
>grant read,write on directory dump to hr,system,scott,sh;
$expdp system/oracle directory=dump dumpfile=test_m.dmp transport_tablespaces=test;
3、(目标与原使用相同的字节序endian,若不同需要用RMAN转换:
RMAN>sql 'alter tablespace hr read only convert tablespace hr to platform '操作系统平台' format '路径';
4、传送元数据和数据两部分文件到catdb:
$cp /u01/dump/tbs2_m.dmp /u01/catdb/dump;
$cp /u01/app/oracle/oradata/orcl/tbs2.dbf /u01/app/oracle/oradata/catdb;
5、使用datapump导入metadata:
$export $ORACLE_SID=catdb
$impdp system/oracle directory=dump dumpfile=test_m.dmp transport_datafiles=/u01/app/oracle/oradata/catdb/tbs2.dbf;//???
6、置表为read write:
>alter tablespace test read write;
移动数据库。
1、备份源库 orcl数据库
RMAN>backup database format '/u01/app/oracle/backup/%U';
RMAN>backup archivelog all format '/u01/app/oracle/backup/%U';
修改参数文件--
>create pfile from spfile;//生成initorcl.ora
initorcl.ora改名initprod.ora
在spfile中添加(数据库改名):
db_file_name_convert='orcl','prod';
log_file_name_convert='orcl','prod';
创建spfile中相应的目录:
启动数据库--
$export $ORACLE_SID=prod;
$sqlplus / as sysdba;
>startup nomount;
使用RMAN连接--
$export $ORACLE_SID=prod;
$rman sys/oracle@orcl auxiliary /;//连接辅助数据库
RMAN>duplicate target database to prod;
恢复数据库:
run {
sql 'alter database datafile 4,5,6 offline';
set newname for datafile 4 to '/u01/app/oracle/oradata/orcl/users01.dbf';
set newname for datafile 5 to '/u01/app/oracle/oradata/orcl/example01.dbf';
set newname for datafile 6 to '/u01/app/oracle/oradata/orcl/test.dbf';
restore datafile 4,5,6;
switch datafile 4;
switch datafile 5;
switch datafile 6;
recover datafile 4,5,6;
sql 'alter database datafile 4,5,6 online';
}
改fstab参数:
>startup nomount
$vi /etc/fstab
tmpfs /dev/shm tmpfs defaults,size=4g 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/VolGroup00/LogVol01 swap swap defaults 0 0
#mount -o remount /dev/shm
报名考试:VOE网站注册OC号,Oracle网站注册号并绑定,找徐老预约考试,考试时间和科目。