Oracle 第2章 Oracle查询、数据类型、函数
Oracle 第4章 同义词、序列、视图、索引
Oracle 第3章 锁、表分区
1、技术目标
- 理解锁定的概念
- 使用表分区
2、锁定的概念
- 多个用户可同时访问相同数据,锁是数据库用来控制共享资源并发访问的机制
- Oracle提供的锁可以确保多用户环境下数据的完整性、一致性
- 锁能用于保护正在被修改的数据
-
在提交或回滚事务之前,Oracle会锁定正在被修改的数据,直到提交或回滚了事务之后,锁会自动释放,其他用户才能更新数据 例如:库存中某商品只剩1件,某用户正在在线订购该商品,与该操作相关的数据,也就是这件商品的记录可以锁定,以防止其他用户"同时购买"该商品而修改该记录
大多数情况下,锁不需要开发者干预 ,Oracle会自动完成锁定,比如修改数据时,Oracle提供了锁定操作,以便于需要显示锁定数据时使用。锁定的特点如下:
- 一致性:一次只允许一个用户修改数据,以保证数据的统一
- 完整性:提供正确的数据,某用户所修改的数据会反映给所有其他用户
- 并发性:允许多用户同时访问同一数据,如,某用户正在修改商品库存时,其他用户可以同时查看库存信息,某用户正在更新数据时,其他用户就不能同时删除该数据
3、锁的类型
锁有两种类型:行级锁 (用于特定行)、表级锁 (用于整个表)
3.1)行级锁
对正在被修改的行进行锁定。其他用户可以访问其余的行,如图
行级锁是一种排他锁 ,可防止其他事务修改行,但不会阻止读取,
在使用insert、update、delete以及select ... for update等
语句时,Oracle会自动应用行级锁,select ... for update
语句可每次选择多行记录进行更新,这些记录会被锁定,直到
回滚或提交该事务后锁才会释放,其他用户才可编辑这些记录
select ... for update语句的完整语法如下:
select ... for update [of 列名集合] [wait 秒数 | nowait];
of子句指定需要锁定的列
wait子句指定等待其他用户释放锁的时间(秒),防止无限期等待
使用: 锁定vencode为V002的记录中oDate和delDate两列,然后再修改
SELECT * FROM orderMaster WHERE vencode=’V002’
FOR UPDATE OF oDate, delDate;
UPDATE orderMaster SET delDate=’18-8月-08’ WHERE
vencode=’V002’;
COMMIT;--事务提交后释放锁定
使用"for update wait"子句的优点有:
- 防止无期限等待被锁定的行
- 可在应用程序中对锁定的等待时间进行设置
3.2)表级锁
表级锁用于保护表数据,使用"lock table "语句显示锁定表。在事务处理中,
表级锁用来限制对表的添加、更新和删除等操作,具体语法如下:
lock table 表名 in 锁定模式 mode [nowait];
nowait关键字可防止无限期等待其他用户释放锁
锁定模式有如下内容:
- 行共享(row share, rs):允许其他用户访问和锁定表,禁止排他锁定整个表
- 行排他(row exclusive, rx):在行共享模式基础上,禁止其他用户在表上使用共享锁
- 共享(share, s):共享锁将锁定表,只允许其他用户查询表中的行,不允许添加、更新或删除行,多个用户可同时在同一表中设置共享锁(允许资源共享) 例如,每天的结帐操作时需更新日销售额表,可在更新该表示设置共享锁以确保数据一致性
- 共享行排他(share row exclusive, srx):比共享锁更多的限制,防止其他事务在表上使用共享锁、共享行排他锁以及排他锁
- 排他(exclusive, x):对表执行的最大限制,其他用户只能查询该表的记录,该锁防止其他事务对表做任何更新或在表上设置任何类型的锁
使用: 以共享模式锁定orderMaster表
lock table orderMaster in share mode;
注意:执行commit或rollback命令可释放锁定
某用户对表锁定时未使用nowait子句,如该表已被另外的用户
锁定,那么他将无限期等待,直到锁定该表的用户使用commit
或rollback语句释放锁
4、死锁
当两个事务相互等待对方完成任务时,会出现死锁。比如用户A锁定了对象
X,用户B锁定了对象Y,用户A再锁定Y,用户B再锁定X,两位用户需要等
待对方释放锁,此时两个用户处于僵持状态,无法继续处理业务,这种情况
Oracle会自动检测死锁,通过终止两个事务之一来解决问题,如图
死锁在Oracle中极少出现,一般不用考虑此问题,可以通过人为制造环境来
产生死锁
5、表分区
Oracle可管理包含海量数据的表,如,公司的订单表可能会增加到百万行,
大小超过2GB,随着表的增大,数据管理随之变得困难,要查找某条记录
需要搜索整个表,会消耗大量的系统资源和时间。Oracle提供的表分区技
术可改善系统性能
表分区允许用户把一个表中的行分为几个部分,不同的部分还可存储在不
同的位置。被分区的表称为分区表,划分出的每一个部分成为一个分区
表分区有许多优势 :
- 可改善表的查询性能,在对表进行分区后,用户执行SQL查询时可以只访问表中的特定分区
- 表更容易管理,因为分区表的数据存储在多个部分中,按分区加载和删除数据比在表中加载和删除更容易
- 便于备份和恢复,可独立备份和恢复每个分区
- 提高数据安全性,将不同的分区分布在不同的磁盘,可减小所有分区数据同时损坏的可能
应用程序不用知道表已分区,在更新和查询分区表时和普通表的操作一
样,但Oracle优化程序知道表已被分区
注意:要分区的表不能具有LONG和LONG ROW数据类型的列
Oracle提供4种分区方法:
- 范围分区
- 散列分区
- 复合分区
- 列表分区
6、范围分区
范围分区根据表的某列或多列的值范围,决定将数据存储在哪个分区上,
比如,可根据序号分区,根据记录的创建日期分区等
创建分区的语法,在create table语句中增加partition子句可创建分区表,
按范围分区的语法为:
create table 表名
(
......
)
partition by range (column_name)
(
partition part1 value less than(range1) [tablespace tbs1],
partition part2 value less than(range2) [tablespace tbs2],
...
partition partN value less than(rangeN) [tablespace tbsN],
)
语法说明:
column_name 为创建范围分区的列,其列值称为分区键
part1 ... partN 为分区名
range1 ... MAXVALUE 为分区的边界值
tbs1 ... tbsN 为分区所在的表空间,tablespace是可选项
范围分区注意事项:
- 每个分区的边界值必须小于下一个分区的边界值
- 每个分区中,只需指定其范围的最大值
- 所有行的分区键都要小于( < )该分区的边界值
- 最后一个分区中,MAXVALUE关键字代表边界的最大值,Oracle使用这个分区来存储前面几个分区中不能存储的数据,范围的最小值由Oracle隐含定义
使用1: 购物商场根据销售成本(salesCost)对Sales表中的数据进行分区,
每个分区有一个分区界限用以限制分区范围,按逻辑范围进行分区,
create table Sales
(
productId varchar2(5),
salesDate date not null,
salesCost number(10)
)
partition by range(salesCost)
(
partition P1 values less than (1000),
partition P2 values less than (2000),
partition P3 values less than (3000),
);
说明:
创建Sales表时创建了3个分区,P1分区包含销售成本低于1000的所有
产品,P2分区包含销售成本低于2000但高于或等于1000的所有产品
使用2: 分区列为date数据类型的情况,必须使用年份为4字符格式掩码
的to_date()函数指定分区边界,
create table sales2
(
productId varchar2(5),
salesDate date not null,
salesCost number(10)
)
partition by range(salesDate)
(
partition P1 values less than (to_date('2006-01-01', 'YYYY-MM-DD')),
partition P2 values less than (to_date('2007-01-01', 'YYYY-MM-DD')),
partition P3 values less than (MAXVALUE),
);
说明: 根据销售日期将表分为3个分区,第一个分区存储2006年以前
的数据,第二个分区存储2006年度的数据,第三个分区存储2007年
以后的数据
7、散列分区
散列分区通过在分区键值上执行一个散列函数 来决定数据的物理位置,
在范围分区中分区键的连续值通常存储在相同的分区中,而散列分区
会把记录平均分布到不同的分区,减少磁盘I/O争用的可能性,
散列分区需要用户指定表所需的分区数目以及存储分区的物理位置,
将散列算法应用于分区键后,散列分区会将数据分布到适当的分区,
语法如下:
partition by hash (column_name)
partitions number_of_partitions [store in (tablespace_list)];
或者
partition by hash (column_name)
(
partition part1 [tablespace tbs1],
partition part2 [tablespace tbs2],
...
partition partN [tablespace tbsN],
)
语法说明:
column_name 为作为基础创建散列分区的列
number_of_partitions 为分区数量,使用这种方式会自动生成分区名
tablespace_list 为分区使用的表空间,如果分区数量超过表空间数量,
分区会以循环的方式分配到表空间中
part1 ... partN 为分区名
使用1: 创建Employee表,设置4个散列分区,department列为分区键
create table employee
(
empId number(4),
empName varchar2(14),
empAddress varchar2(15),
department varchar2(10)
)
partition by hash(department) partitions 4;
使用2: 创建表MyEmp并设置2个散列分区
create table MyEmp
(
eId number(4),
eName varchar2(20)
)
partition by hash(empId)
(
partition part1,
partition part2
);
8、复合分区
复合分区是范围分区和散列分区的结合,创建复合分区时,先按范围对
数据进行分区,然后在这些分区内创建散列分区。复合分区即具有范围
分区便于管理的特定,有具有散列分区在数据放置和并行操作方面的优势
复合分区语法:
partition by range (column_name1)
subpartition by hash(column_name2)
subpartition number_of_partitions [store in (tablespace_list)]
(
partition part1 value less than(range1),
partition part2 value less than(range2),
...
partition partN value less than(MAXVALUE),
);
语法说明:
column_name1
column_name2
number_of_partitions
part1 ... partN 为分区名
range 为范围分区的边界值
使用: 创建表Sales,设置复合分区,先根据salesDate列创建4个范
围分区,再根据productId创建子分区,子分区采用散列分区,共创
建5个子分区,总共创建20个子分区
create table Sales
(
productId varchar2(5),
salesDate date not null,
salesCost number(10)
)
partition by range(salesDate)
subpartition by hash(productId)
subpartitions 5
(
partition P1 values less than(date '2008-03-01'),
partition P2 values less than(date '2008-06-01'),
partition P3 values less than(date '2008-09-01'),
partition P4 values less than(MAXVALUE),
);
9、列表分区
列表分区允许用户明确地控制行到分区的映射,列表分区允许按自然方式
对无序和不相关的数据集进行分组和组织,语法如下:
partition by list (column_name)
(
partition part1 values (values_list1),
partition part2 values (values_list2),
...
partition partN values (DEFAULT)
);
语法说明:
column_name 为创建列表分区的基础列
part1 ... partN 为分区名
values_list 为对应分区的分区键值列表
DEFAULT 关键字为允许存储前面的分区不能存储的记录
使用: 根据职员住址对Employee表进行分区,north分区只包含地址
为"辽宁"的记录,如果用户输入的值是"广东",则Oracle会拒绝该值,
因为没有创建可以包含该值的分区
create Employee
(
empId number(4),
empName varchar2(14),
empAddress varchar2(15),
department varchar2(10)
)
partition by list(empAddress)
(
partition north values('辽宁'),
partition west values('西藏', '青海'),
partition south values('福建', '海南'),
partition east values('江苏', '上海')
);
10、按分区查询、删除记录
使用1: 查询表分区的记录
select * from 表名 partition (分区名);
使用2: 删除表分区的记录
delete from 表名 partition (分区名);
11、分区维护
分区维护是指修改分区表的分区,比如可以向现有表添加新分区,将
分区移动到其他表空间中等等
某些分区维护操作时计划事件,如在历史数据库中,数据库管理员定
期从数据库中删除最旧的分区并添加一组新的分区,该删除和添加操作
将定期执行
其他分区维护操作时费计划事件,用于解决应用程序或系统问题,例如
意料之外的事务处理活动可能会迫使DBA拆分分区以便重新平衡I/O负载
部分分区维护操作如下:
- 添加分区
- 删除分区
- 截断分区
- 合并分区
- 拆分分区
11.1)添加分区
alert table 表名 add partition 新分区名 values less than (边界值);
该语句用于在最后一个分区后添加新分区,如果要在表的开始或中间
位置添加分区,或者最高分区的分区边界是MAXVALUE,则应使用
split partition语句
11.2)删除分区
alter table 表名 drop partition 分区名;
删除分区会连分区中的数据一起删除
11.3)截断分区
alter table 表名 truncate partition 分区名;
截断分区会删除表分区中的所有记录
11.4)合并分区
alter table 表名
merge partitions 分区名1, 分区名2
into 新分区名;
可将范围分区或复合分区表的两相邻分区连接起来,合并后的
分区将继承两个分区的较高上界
11.5)拆分分区
alter table 表名
split partition 分区名 at (边界值)
into (partition 新分区名1, partition 新分区名2);
可在表的开头或中间添加分区,拆分分区允许用户将一个分区
拆分为两个分区,当分区过大时可对分区进行拆分
使用:将Sales表的P3分区拆分为P31和P32两个分区,原P3分区
存储2007年以后的数据,拆分为两个分区,一个存放2007年度数
据,另一个存放2008年以后的数据
alter table Sales split partition P3 at (date '2008-01-01')
into (partition P31, partition P32);
12、总结
- 锁用于保护多用户环境下被修改的数据
- 锁分为两种级别,即行级锁和表级锁
- 表分区允许将一个表划分成几部分,以改善大型应用系统的性能
- 分区方法包括范围分区、散列分区、复合分区和列表分区
- 分区维护操作包括添加、删除、截断、合并和拆分分区
Oracle 第2章 Oracle查询、数据类型、函数
Oracle 第4章 同义词、序列、视图、索引
相关推荐
Oracle第三章锁和分区表.ppt
"利用Kettle自动创建Oracle表分区" 在本篇文章中,将会介绍如何使用Kettle自动创建Oracle表分区。Oracle表分区是一种非常重要的数据库优化技术,它可以将大型表分割成多个小的独立表,从而提高查询效率和数据管理...
3. **执行计划与表分区的关联** - **分区消除**:如果查询只涉及部分分区,优化器可以避免扫描整个表,从而提高效率。 - **分区并行执行**:Oracle允许在不同分区上并行执行查询,进一步提升处理大量数据的速度。 ...
### Oracle 数据表分区详解 #### 一、分区表理论知识 Oracle 提供了表分区功能以支持非常大型的数据库(VLDB)。通过分区技术,可以根据指定的分区键将数据分散到不同的物理位置,从而实现更高效的数据管理和查询...
支持自动ORACLE大表分区: 版本进度: 31. 20110420 V2.2 支持任意表任意时间字段分区 以下为安装部署部分: 1.分区相关脚本部署执行顺序,安装前请确保该用户拥有管理员权限, 同时请执行GRANT CREATE ANY TABLE ...
Oracle数据库中的表分区是一种优化大型数据表性能的技术,它将一个大表划分为多个更小、更易管理的部分,每个部分称为一个分区。通过分区,可以提高查询速度、简化管理和维护,以及改善备份和恢复的效率。以下是...
本案例在2001年第三季度建立了一个新的表空间,并为表添加了新的分区。新分区的创建需要指定分区的名称、范围以及对应的表空间。 四、注意事项 在创建分区表时,需要确保数据库的分区功能已经启用,即在v$option...
### ORACLE-分区表的用法 #### 1. 表空间及分区表的概念 - **表空间**:表空间是Oracle数据库中的基本存储单元,它由一个或多个数据文件组成,用于存储数据库中的所有数据对象(如表、索引等)。在Oracle中,所有...
第三章 锁和表分区; 第四章 数据库对象; 第五章 Oracle 中的 OOP 概念; 第六章 PL/SQL 简介; 第七章 异常和游标管理; 第八章 子程序和程序包; 第九章 数据库触发器和内置程序包; 第十章 集合和成员函数。
- **组合分区(Composite Partitioning)**:允许在第一层使用一种分区方法,在第二层使用另一种分区方法,如 Range-List 或 Range-Hash 分区。 #### 二、何时使用哪种分区类型 - **当使用范围分区**:适用于数据...
### Oracle表分区详解 #### 一、表空间及分区表的概念 **表空间**:在Oracle数据库中,表空间是一个或多个数据文件的集合。所有数据对象(如表、索引等)都存放在特定的表空间中。由于主要存放的是表,因此被称为...
在"Oracle幻灯片第三章"中,我们重点探讨的是Oracle的锁机制以及表分区这两项核心概念。 首先,让我们深入理解Oracle的锁机制。在多用户环境下,为了保证数据的一致性和完整性,Oracle数据库采用了多种类型的锁来...
### Oracle数据库应用:锁和表分区 #### 一、锁的概念及作用 **锁**是数据库管理系统为了控制并发访问而采用的一种机制。在多用户环境中,为了保证数据的一致性和完整性,Oracle数据库通过锁机制来保护正在被修改...
例如,创建一个物料交易表`material_transactions`,可以按交易ID的范围进行分区,如将交易ID小于30000000的记录存储在第一个分区,小于60000000的记录存储在第二个分区,其余的记录存储在第三个分区。这样,每个...
3. 可用性保证:在故障发生时,只影响到单个分区,而不是整个表,提高了系统的整体可用性。 4. 信息生命周期管理:通过分区,可以实现数据的“分层归档”,即将不再频繁访问的历史数据存放在低成本的存储上,同时...
例如,首先对范围一散列组合分区表进行范围分区,然后使用第二个数据分配方法为每个分区进一步划分子分区。 分区扩展是 Oracle 11g 中的一种功能,包括间隔分区、引用分区与基于虚拟列的分区。分区扩展显著增强分区...