首页 置换 选车 估价 问答 生活 经销商 车管所 汽车资讯 汽车销量 车牌查询 今日油价 天气预报
您的位置: 首页 > 生活 > 科技 > oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)
oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)
更新时间:2024-07-08 18:26:23
概述

物理设计就是根据所选择的关系型数据库的特点对逻辑模型进行存储结构设计。它涉及的内容包含以下4方面:1. 定义数据库、表及字段的命名规范;2. 选择合适的存储引擎或者存储结构;3. 为表中的字段选择合适的数据类型;4. 建立数据库结构。

今天主要谈谈表和索引的设计建议。

oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)1


1、表物理设计基本建议

1)除特殊需求,建议采用普通的堆表(Help Table)。

2)每个表在创建的时候,建议指定所在的表空间。不要采用默认表空间。以防止表建立在系统表空间上导致的性能和安全问题。

3)建议应用设计开发人员提供每张表的DNL操作频度数值。如果update操作频度高,则可将PCTFREE设计为较高(10%,20%,...),反之,则可将PCTFREE设置为较高(1%,...)。

当表中存在大量的delete操作时。PCTUSED值的增大,将提高表空间的利用率,并提高insert和update操作的性能。因此,建议将大量进行delete操作的表的PCTUSED设为60,否则设为缺省值40。

4)对并发访问量比较高的表和索引,将INITRANS设置较大,特别是针对索引,例如设置INITRANS设为10。

5)对比较小的代码和参数表,可考虑IOT表技术。

6)如果某几个静态表关系比较密切,则可以采用聚族表的方法。

以下就是XX表创建脚本。

create table t_card_accnt( card_no char(19) not null, card_medium char(1) not null, card_type char(1) not null, card_class char(2) not null, cstm_name varchar2(40) not null, app_date number(6) not null, Pwd RAW(8) not null) PCTFREE 20 PCTUSED 40 INITRANS 2 MAXTRANS 255 TABLESPACE TS_DATA LOGGING STORAGE ( INITIAL 104857600 NEXT 10485760 PCTINCREASE 0 MINEXTENTS 1 MAXEXTENTS 2147483645 FREELISTS 5 FREELISTS GROUPSS 5 BUFFER_POOL DEFAULT) ENABLE ROW MOVEMENT PARTITION BY HASH(CARD_NO) PARTITIONS 64 STORE IN (TS_DATA);

需要说明的是,上述脚本是Oracle Date Modeler工具生成的。实际上,如采取手工编写方法,大量物理属性可以采用缺省值,例如STORAGE短语、ENABLE ROW MOVEMENT等均可省略。


2、索引设计基本建议

以下不仅从物理设计,而且从应用开发角度提供索引设计的基本建议。

1)通常而言,交易系统设立为B*树索引,对数据仓库系统,则可考虑Bitmap、Bitmap Join等索引。

2)通过分析应用软件对数据访问方式。展开索引设计。

3)索引与数据分别存储在不同的表空间。

4)不要对索引字段进行运算。

5)不要对索引字段进行格式转换。

6)不要对索引字段使用函数。

7)加强索引使用和索引效率的分析。


3、B*树单字段索引设计建议

oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)2

1)分析SQL语句中的约束条件字段。

2)如果约束条件字段不固定,建议创建针对单字段的普通B*树索引。

3)选择可选性最高的字段建立索引。

4)如果是多表连接SQL语句,注意被驱动表 (Drived Table)的连接字段是否需要创建索引。

5)通过多种SQL分析工具。分析执行计划并以量化形式评估效果。


4、复合索引设计建议

oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)3

1)分析SQL语句中的约束条件字段。

2)如果约束条件字段比较固定,则优先考虑创建针对多字段的普通B*树复合索引。例如当时涉及月份、账号、金融机构代码三个字段的条件,则可以考虑建立一个复合索引。

3)如果单个字段是主键或唯一字段,或者可选性非常高的字段,尽管约束条件字段比较固定,也不一定要建成复合索引,可建成单字段索引,降低复合索引开销。

4)在复合索引设计中,需首先考虑复合索引第一个设计原则:复合索引的前缀性(Prefixing)。即SQL语句中,只有复合索引的第一个字段作为约束条件,该复合索引字段才会启用。在复合索引设计中,其次应考虑复合索引的可选性(Selectivity或Cardinality)。即按可选性高低,进行复合索引字段的排序。例如将上述索引的字段顺序排列为:账号、金融机构代码、月份。

5)如果条件设计的字段不固定,组合比较灵活,则分别为月份、账号、金融机构三个字段建立索引。

6)如果是多表连接SQL语句,注意是否可以在被驱动表的连接字段与该表的其他约束条件字段上,创建复合索引。

7)通过多种SQL分析工具,分析执行计划并以量化形式评估效果。


后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下!

oracle数据库创建分区表(详解Oracle数据库物理设计--表和索引设计建议)4

,
相关推荐RECOMMEND
台式电脑怎样添加蓝牙功能(台式电脑可以增加蓝牙功能吗)
很多用户使用台式电脑时,发现它没有蓝牙功能,想要增加,但不知道是否可以,本篇文章说说与其相关的知识。台式电脑可以增加蓝牙功能吗?答案是“可以”,只要用户的台式电脑有闲置的USB接口,那么就可以额外增加...
计算机三大操作系统的功能(国产计算机操作系统布局)
近日,统信软件宣布,将以旗下的“深度(deepin)社区”为基础,建设立足中国、面向全球的桌面操作系统根社区,打造中国桌面操作系统的根系统。相比Windows、苹果的闭环体系,Linux属于开放生态。...
2000以内的oppo手机哪款性价比高(1999元手机性价比排行榜)
#头条创作挑战赛#9月份和10月份这俩月,大多数都是以性价比机型为主的,尤其是一个月之后的双十一,许多厂家还会针对这个活动推出特别款机型,可以说为了销量做出了很多,有新换机的朋友如果追求极致性价比的话...
宋ev500值得买吗(电驹听说宋EV)
比亚迪宋EV500是一款A级纯电动SUV,0-50km/h加速时间3.9秒,NEDC续航里程400km,电驹实测最大续航里程570km,平均时速29km/h的纯市区续航里程超过370km。这是比亚迪3...
dos系统和windows系统(1分钟了解windos系统版本优缺点)
我们在使用电脑时,离不开windows操作系统,那么你知道各个版本之间的优缺点吗?你现在使用的系统就是最适合你的吗?今天笔者就和大家聊聊这个问题。WindowsxpXp版本对于很多小年轻来说,只是存在...
cad工具栏有问号怎么回事(CAD工具栏变成了问号 )
大家先别一看到题目就说变成问号肯定是字体库的问题,这里碰到的情况不是图纸里面的标注和文字变成问号,而是工具栏变成为了问号,如下图:遇到这种情况的其实不多,参考了一些文章和论坛,给大家总结一下,网友处理...