读oracle one on one笔记
2008-10-22 16:20
267 查看
MTS 多线程服务器 不要再MTS上执行长时间的事物
AQ 高级队列
使用绑定变量
并行控制
多版本数据(delete命令把数据复制到成为回滚段的数据空间 )
redo(重做)日志
undo(撤销)日志 回滚段
create table t(pk number primary key,...);
create sequence t_seq;
create trigger t_trigger before insert on t from each row
begin
select t_seq.nextval into :new.pk from dual;
end;
create profile one_session limit sessions-per_user l;
alter user scott profile one_session;
alter system set rescource_limit=true;
FGAC(Fine Grained Access Control) 精细存取控制
Oracle体系结构
文件-- 参数文件,数据文件,临时数据文件和重做日志文件
系统全局区域(system global area ,SGA)的内存机构----SGA,PGA和UGA之间的关系
无力进程与线程---服务器进程,后台进程和从属进程
实例与数据库
数据库---物理操作系统文件的集合
实例---一组Oracle进程和SGA
_trace_files_public=true
开发人员应该频繁使用sql_trace,timed_statistics 和tkprof实用程序
SGA system global area
PGA process global area 内存的进程段
UGA user Global area
不需要索引
不从父表中删除
不更新父表的唯一/主码值
不从父表连接到子表、
for update
创建两个锁定 一个锁定放在选择的行上(一个专有的锁,没有别人能在专有模式下锁定那个指定的行)。另一个锁是row share table锁
防止其他会话在表上放置专有锁,防止他们更改表结构。
v$transcation 包含每个活动事务的入口
v$session 向我们展示登陆的会话
v$lock 包含所有被持有的锁定的入口,也包含正在等待锁定的会话的入口
select username,v$lock.sid,
trunc(id1/power(2,16)) rbs,
bitand(id1,to_number('ffff','xxxx'))+0 slot,
id2 seq,
lmode,
request
from v$lock,V$session
where v$lock.type='TX'
and v$lock.sid= v$session.sid
and v$session.username =USER;
update scott.dept set deptno=deptno+10;
select xidusn,xidslot,xidsqn from v$transaction
update scott.emp set ename= upper(ename);
update scott.dept set deptno=deptno-10;
DBMS_LOCK(同一时间只有一个用户可以写入文件) utl_file
不使用绑定变量和频繁地执行硬分析, 由于库高速缓存的竞争和CPU的过度使用,都会导致严重地降低并行特性。即使改成使用绑定变量
软分析太频繁也会导致性能下降。
一次性Commit
必须产生重做日志,他不是额外开销,也不是浪费,是数据库的工作方式。
一些SQL语句和操作支持使用NOLOGGING语句,并不意味完成此对象的所有操作而不产生重做日志,只是某些非常特定的操作能产生
明显少的重做。
ora-01555 : Snapshot too old;
对在系统上执行的工作,回滚段太小
程序产生交叉commit
快清除
AQ 高级队列
使用绑定变量
并行控制
多版本数据(delete命令把数据复制到成为回滚段的数据空间 )
redo(重做)日志
undo(撤销)日志 回滚段
create table t(pk number primary key,...);
create sequence t_seq;
create trigger t_trigger before insert on t from each row
begin
select t_seq.nextval into :new.pk from dual;
end;
create profile one_session limit sessions-per_user l;
alter user scott profile one_session;
alter system set rescource_limit=true;
FGAC(Fine Grained Access Control) 精细存取控制
Oracle体系结构
文件-- 参数文件,数据文件,临时数据文件和重做日志文件
系统全局区域(system global area ,SGA)的内存机构----SGA,PGA和UGA之间的关系
无力进程与线程---服务器进程,后台进程和从属进程
实例与数据库
数据库---物理操作系统文件的集合
实例---一组Oracle进程和SGA
_trace_files_public=true
开发人员应该频繁使用sql_trace,timed_statistics 和tkprof实用程序
SGA system global area
PGA process global area 内存的进程段
UGA user Global area
不需要索引
不从父表中删除
不更新父表的唯一/主码值
不从父表连接到子表、
for update
创建两个锁定 一个锁定放在选择的行上(一个专有的锁,没有别人能在专有模式下锁定那个指定的行)。另一个锁是row share table锁
防止其他会话在表上放置专有锁,防止他们更改表结构。
v$transcation 包含每个活动事务的入口
v$session 向我们展示登陆的会话
v$lock 包含所有被持有的锁定的入口,也包含正在等待锁定的会话的入口
select username,v$lock.sid,
trunc(id1/power(2,16)) rbs,
bitand(id1,to_number('ffff','xxxx'))+0 slot,
id2 seq,
lmode,
request
from v$lock,V$session
where v$lock.type='TX'
and v$lock.sid= v$session.sid
and v$session.username =USER;
update scott.dept set deptno=deptno+10;
select xidusn,xidslot,xidsqn from v$transaction
update scott.emp set ename= upper(ename);
update scott.dept set deptno=deptno-10;
DBMS_LOCK(同一时间只有一个用户可以写入文件) utl_file
不使用绑定变量和频繁地执行硬分析, 由于库高速缓存的竞争和CPU的过度使用,都会导致严重地降低并行特性。即使改成使用绑定变量
软分析太频繁也会导致性能下降。
一次性Commit
必须产生重做日志,他不是额外开销,也不是浪费,是数据库的工作方式。
一些SQL语句和操作支持使用NOLOGGING语句,并不意味完成此对象的所有操作而不产生重做日志,只是某些非常特定的操作能产生
明显少的重做。
ora-01555 : Snapshot too old;
对在系统上执行的工作,回滚段太小
程序产生交叉commit
快清除
相关文章推荐
- Differences Between Enterprise, Standard and Standard One Editions on Oracle 11.2 (Doc ID 1084132.1)
- Expert One-on-One Oracle Chapter 13 物化视图 读书笔记(1)
- Expert-One-on-One-J2EE笔记
- Expert One-on-One Oracle Chapter 13 物化视图 读书笔记(4)
- 用一个月时间看完《Expert one on one Oracle》
- Oracle by Example - Oracle Database 10g Release 2 on a Single Database Instance (All In One CHM)
- Expert One-on-One Oracle Chapter 13 物化视图 读书笔记(2)
- 放弃《Expert one on one Oracle》
- Expert One-on-One Oracle Chapter 14 分区表 读书笔记(1)-分区表的可用性
- Expert One-on-One Oracle Chapter 13 物化视图 读书笔记(3)
- Oracle Database :Oracle11g SQL开发指南学习笔记之(6):Oracle概念
- Oracle笔记(五) 单行函数
- hacking oracle笔记
- Oracle笔记(5)
- 【安博培训笔记】Oracle4 事务和数据库对象 作业20130910
- How To Commit Just One Data Block Changes In Oracle Forms
- one artical on pci hotplug framework
- maven之构建oracle的jdbc学习笔记_保存点_SQLXml_ojdbc6驱动连接简析
- oracle 笔记2(Fundamentals II)
- Ruby on rails Mac开发 入门笔记(一)