Oracle之表的设计
网友:or
文章列表
2024-03-21 19:24:34

- 表的设计
- 普通堆表
- 缺点
- 表更新日志开销较大
- 查看产生多少日志
- select a.name,b.value from v$statname a,v$mystat b where a.statistic#=b.statistic# and a.name='redo size';
- 表的更新操作,无论是删除、插入还是修改,都会产生日志。更新操作产生的日志最多
- 查看产生redo视图
- select * from v_redo_size;
- Delete无法释放空间
- delete删除并不能释放空间,虽将很多块的记录删除,但空块仍保留,Oracle在查询时依然会支查询空块。而truncate是一种高水平的动作,这个空块被回收,空间也就释放了。truncate是一种DDL操作而非DML操作,truncate后不带条件。
- 全局临时表
- 优点
- 产生日志少
- 无论是插入更新还是删除,操作普通表产生的日志都比全局临时表要多。
- 分区表
- 分区表原理及类型
- 原理
- 分区表会产生多个SEGMENT,而普通表仅有一个SEGMENT。
- 化整为零,将大对象切割成多个小对象,从而使得指定的小对象定位到数据,最终减少访问路径,尽量少做事解决问题。
- 类型
- HASH分区
- 缺点
- 系统自行创建分区名称,无法将指定数据到指定的分区。
- 优点
- 将数据根据一定的HASH算法,均匀分布到不同分区,避免查询数据集中,改善IO。可精确匹配,无法范围扫描。
- 组合分区
- Oracle 11g以前的版本只支持range_list和range_hash组合
- 分区索引
- 全局索引
- create index idx_part_tab_date on range_part_tab(deal_date);
- 局部索引
- create index idx_part_tab_area on rang_part_tab(area_code) loca;
- 查看索引表情况
- select index_name,status from user_indexes where index_name in(...)
- 分区表相关易错点
- 分区索引失效
- 分区转移、切割、合并、增删等,也和分区truncate是类似的,都允许增加update global indexes关键字,从而避免全局索引失效。
- 优点
- 高效的记录转移
- exchange partition part_xx with table mid_table
- 分区交换,两张表的字段完全相同
- alter table range_part_tab exchange partition p8 with table mid_table;
- mid_table是无数据的,若存在数据则会交替交换
- 切割分区
- alter table range_part_tab split partition p_max at (To_DATE('2022-01-01','YYYY-MM-DD')) into (partition p2022_01,partition P_MAX);
- into部分说明分区被切割成两个分区,P_MAX是新的分区名,也可沿用已存在的分区名
- 分区合并
- alter table range_part_tab merge partitions p2022_01,P_MAX into partition p_max;
- into部分为合并后的分区名,可以是新的分区名,也可以沿用已存在的分区名
- 索引组织表
- 最大的特点是表就是索引,索引就是表,这是一种特别的设计,无需访问表
- 此文章为个人做的笔记,如有写的不对或你在表设计方面还有什么高见,评论区见