您当前的位置:首页 > 电脑百科 > 数据库 > Oracle

详解Oracle数据库物理设计--表和索引设计建议

时间:2019-10-11 09:44:02  来源:  作者:

概述

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

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

详解Oracle数据库物理设计--表和索引设计建议

 


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数据库物理设计--表和索引设计建议

 

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

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

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

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

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


4、复合索引设计建议

详解Oracle数据库物理设计--表和索引设计建议

 

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

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

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

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

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

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

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



Tags:Oracle   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  Tags: Oracle  点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  Tags: Oracle  点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  Tags: Oracle  点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Tags: Oracle  点击:(88)  评论:(0)  加入收藏
2021年免费vps服务器申请,oracle永久免费使用。Oracle 云免费套餐只需注册 Oracle 云帐户即可获取,不仅包含丰富的 Always Free 云服务,还提供 300 美元的免费试用储值,让您可以...【详细内容】
2021-09-08  Tags: Oracle  点击:(109)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  Tags: Oracle  点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  Tags: Oracle  点击:(88)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  Tags: Oracle  点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity('河北沧州东塑股份有限公司','河北沧州东...【详细内容】
2021-07-07  Tags: Oracle  点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  Tags: Oracle  点击:(103)  评论:(0)  加入收藏
▌简易百科推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  守护梦想2022    Tags:Oracle   点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  JasonTang    Tags:Oracle   点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  it运维小土豆  今日头条  Tags:Oracle   点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Java技术栈  掘金  Tags:Oracle   点击:(88)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  free教程    Tags:Oracle日志   点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  大树唛包    Tags:oracle   点击:(88)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  死磕IT    Tags:Oracle rac   点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity('河北沧州东塑股份有限公司','河北沧州东...【详细内容】
2021-07-07  Onceagain75783189    Tags:比较函数   点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  程序猿集锦    Tags:Oracle   点击:(103)  评论:(0)  加入收藏
oarcle数据库真正存放数据的是数据文件(data files),Oarcle表空间(tablespaces)实际上是一个逻辑的概念,他在物理上是并不存在的,那么把一组data files 捻在一起就成为一个表空间。...【详细内容】
2021-04-27  SQL小帅哥  今日头条  Tags:Oracle   点击:(200)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条