首页 > 编程知识 正文

oracle创建唯一索引的语句,oracle索引的建立与使用

时间:2023-05-05 10:15:19 阅读:233792 作者:2461

在Oracle数据库中,创建rxdxh虽然比较简单。但是要合理的创建rxdxh则比较困难了。笔者认为,在创建rxdxh时要做到三个适当,即在适当的表上、适当的列上创建适当数量的rxdxh。虽然这可以通过一句话来概括优化的rxdxh的基本准则,但是要做到这一点的话,需要数据库管理员做出很大的努力。具体的来说,要做到这个三个适当有如下几个要求。

  一、 根据表的大小来创建rxdxh。

  虽然给表创建rxdxh,可以提高查询的效率。但是数据库管理员需要注意的是,rxdxh也需要一定的开销的。为此并不是说给所有的表都创建rxdxh,那么就可以提高数据库的性能。这个认识是错误的。恰恰相反,如果不管三七二十一,给所有的表都创建了rxdxh,那么其反而会给数据库的性能造成负面的影响。因为此时滥用rxdxh的开销可能已经远远大于由此带来的性能方面的收益。所以笔者认为,数据库管理员首先需要做到,为合适的表来建立rxdxh,而不是为所有的表建立rxdxh。

  一般来说,不需要为比较小的表创建rxdxh。如在一个ERP系统的数据库中,department表用来存储企业部门的信息。一般企业的部分也就十几个,最多不会超过一百个。这100条记录对于人来说,可能算是比较多了。但是对于计算机来说,这给他塞塞牙缝都还不够。所以,对类似的小表没有必要建立rxdxh。因为即使建立了rxdxh,其性能也不会得到很大的改善。相反rxdxh建立的开销,如维护成本等等,要比这个要大。也就是说,付出的要比得到的多,显然违反常理。

  另外,就是对于超大的表,也不一定要建立rxdxh。有些表虽然比较大,记录数量非常的多。但是此时为这个表建立rxdxh并一定的合适。如系统中有一张表,其主要用来保存数据库中的一些变更信息。往往这些信息只给数据库管理员使用。此时为这张表建立rxdxh的话,反而不合适。因为这张表很少用到,只有在出问题的时候才需要查看。其次其即使查看,需要查询的纪录也不会很多,可能就是最近一周的更新记录等等。对于对于一些超大的表,建立rxdxh有时候往往不能够达到预计的效果。而且在打表上建立rxdxh,其rxdxh的开销要比普通的表大的多。那么到底是否给大表建立rxdxh呢?笔者认为,主要是看两个方面的内容。首先是需要关注一下,在这张大表中经常需要查询的记录数量。一般来说,如果经常需要查询的数据不超过10%到15%的话,那就没有必要为其建立rxdxh的必要。因为此时建立rxdxh的开销可能要比性能的改善大的多。这个比例只是一个经验的数据。如果数据库管理员需要得出一个比较精确的结论,那么就需要进行测试分析。即数据库管理员需要测试一下全表扫描的时间,看看其是否比建立rxdxh后的查询时间要长或者短。如果是长的话,则说明有建立rxdxh的必要。但是如果没有的话,则说明还是全表扫描速度来的快。此时也就没有必要建立rxdxh了。

  总之,在考虑是否该为表建立rxdxh时,一般来说小表没有建立rxdxh的必要。而对于打表的话,则需要进行实际情况实际分析。简单一点的,可以根据大致的比率来确定。如果要精确一点的,则可以进行全表扫描性能分析,以判断建立rxdxh后是否真的如预期那样改善了数据库性能。

  二、 根据列的特征来创建rxdxh。

  列的特点不同,rxdxh创建的效果也不同。数据库管理员需要了解为哪些列创建rxdxh可以起到事倍功半的效果。同时也需要了解为哪些列创建rxdxh反而起到的是事倍功半的效果。这有利于他们了解到底给为怎么样的字段建立rxdxh。

  根据笔者的经验,往往为如下特征的列创建rxdxh能够起到比较明显的效果。如对于一些重复内容比较少的列,特别是对于那些定义了唯一约束的列。在这些列上建立rxdxh,往往可以起到非常不错的效果。如对于一些null值的列与非Null值的列混合情况下,如果用户需要经常查询所有的非Null值记录的列,则最好为其设置rxdxh。如果经常需要多表连接查询,在用与连接的列上设置rxdxh可以达到事半功倍的效果。

  可见,rxdxh设置的是否恰当,不仅跟数据库设计架构有关,而且还跟企业的经济业务相关。为此,对于一些套装软件,虽然一开始数据库管理员已经做了rxdxh的优化工作。但是随着后来经济数据的增加,这个rxdxh的效果会越来越打折扣。这主要是因为记录的表化影响到了rxdxh优化的效果。所以笔者建议各位数据库管理员,即使采用的是大牌软件公司的套装软件,也需要隔一段时间,如一年,对数据库的rxdxh进行优化。该去掉的去掉,该调整的调整,以提高数据库的性能。

  如在数据库中有一张表是用来保存用户信息的。其中有个字段身份证号码,这是一个唯一的字段。在数据库设计时,给这个字段创建了rxdxh。但是当这个数据库投入使用之后, 用户不怎么输入用户的身份证号码。而且平时也基本不按这个号码来进行查询。当记录月来月多时,这个身份证号码上的rxdxh字段不但不能够改善数据库的查询性能,反而成了鸡肋。对于这些有很多NULL值的列,而且不会经常查询所有的非NULL值记录的列,数据库管理员要下决心,即使清除这些列上的rxdxh。

  所以说rxdxh的优化与调整是一个动态的过程,并不是说数据库设计好之后就不需要经过调整。数据库管理员往往需要根据记录的变化情况,来进行适当的变更。以提高rxdxh的效果。

三、 在一个表上创建多少rxdxh合适?

  虽然说,在表上创建rxdxh的数量没有限制,但是决不是越多越好。也就是说,在创建rxdxh这项事情上,1+1〉2往往不成立。有时候,创建rxdxh越多,其可能会得到适得其反的效果。那么在一个表上,到底给创建多少rxdxh合适呢?这个没有一个明确的标准。而是需要数据库管理员根据实际的用途以及数据库中记录的情况,来进行判断。

  通常来说,表的rxdxh越多,其查询的速度也就越快。但是,表的更新速度则会降低。这主要是因为表的更新(如往表中插入一条记录)速度,反而随着rxdxh的增加而增加。这主要是因为,在更新记录的同时需要更新相关的rxdxh信息。为此,到底在表中创建多少rxdxh合适,就需要在这个更新速度与查询速度之间取得一个均衡点。如对于一些数据仓库或者决策型数据库系统,其主要用来进行查询。相关的记录往往是在数据库初始化的时候倒入。此时,设置的rxdxh多一点,可以提高数据库的查询性能。同时因为记录不怎么更新,所以rxdxh比较多的情况下,也不会影响到更新的速度。即使在起初的时候需要导入大量的数据,此时也可以先将rxdxh禁用掉。等到数据导入完毕后,再启用rxdxh。可以通过这种方式来减少rxdxh对数据更新的影响。相反,如果那些表中经常需要更新记录,如一些事务型的应用系统,数据更新操作是家常便饭的事情。此时如果在一张表中建立过多的rxdxh,则会影响到更新的速度。由于更新操作比较频繁,所以对其的负面影响,要比查询效率提升要大的多。此时就需要限制rxdxh的数量,只在一些必要的字段上建立rxdxh。

  笔者在平时数据库优化时,往往会根据这些表的用途来为列设置rxdxh。可以查询相关的动态视图,看看对于这张表的操作,是更新操作(包括更新、删除、插入等等)占的比例大,还是查询操作占的比例大。当过多的rxdxh已经影响到更新操作的速度时,则数据库管理员就需要先禁用某些rxdxh,以提高数据库的性能。

  总之,在适当的表、适当的列上建立适当的rxdxh。这一句话包含的意思有很多,以上内容只是一部分内容。俗话说,师傅领进门,修行靠自身。笔者在这里指能够点到为止。一些具体的rxdxh优化内容还是需要各位读者在日常工作中去体会与总结。

  在Oracle创建rxdxh的实际操作中会出现的限制条件  

在Oracle创建rxdxh的实际操作中有一些限制条件。就是说表或是列建立的相关rxdxh并不是越多越好,而是相关rxdxh建的越多,反而会影响到Oracle数据库在运行中的整体性能,所以,在建立rxdxh的时候,仍然会有一些限制条件。

 

一是不要对一些记录内容比较少的表建立rxdxh

 

在一个应用系统设计的时候,如设计一个ERP系统的数据库,其虽然有几千张表。但是,并不是每张表都有大量记录的。相反,其中有近一半左右的数据表,可能其存储的数据不会超过百条。如员工登陆帐户密码表、企业部门信息表等等。对于这些记录内容比较少的表,我们建立最好不要为其建立rxdxh。无论是表上的,还是字段上,都不要Oracle建立rxdxh。

 

二是若表中的内容比较大

 

但是,这个表基本上不怎么查询的时候,则只需要在表上建立rxdxh即可;而不需要在字段上建立rxdxh。如现在在ERP系统中,有一张表是“AD_Table”。其存储的是这个数据库中相关表的信息。这张表只有在数据库设计的时候才会用到。故这张表中的记录虽然比较多,但是由于用户用的比较少,所以,一般没有必要为这张表建立列级别上的rxdxh。而直接用表rxdxh来代替。

 

三是在一些NULL字段上

 

要根据实际情况来判断是否要建立rxdxh。如现在有一张人事档案的表格,其上面有两个字段,分别为“身份证号码”与“地区”。有时会为了某个原因,企业需要所有员工都在系统中登记他们的身份证号码,以方便他们办工资卡、社会保险等等。所以人事管理可能需要经常的查询系统,看看有没有没有身份证号码的员工信息。

 

此时,就需要利用条件“IS NULL”来查询我们所需要的记录。故为了提高查询效率,lyc个记录可能为空,并且经常需要以NULL为条件进行查询的时候,则最好给这个字段添加一个rxdxh,并且最好建立位图rxdxh。相反,若虽然可能会以NULL这个条件作为查询的限制语句,但是,用的不是很多的时候,则就没有必要为其建立rxdxh。

 

建议三:多表连接查询的rxdxh设计

 

如现在有一个人事管理系统。人事经理想知道员工的社保缴纳情况。他需要知道员工的姓名、职务、户籍性质(农民户口跟居民户口费用不一样)、缴纳的情况等等。但是,这些信息包含在不同的表中。因为为了提高Oracle数据库的性能,在表中存储的可能只是某些序号,而不是具体的内容。

 

如在社保表中,存储的是员工对应的编号,而不是员工的名字。所以,要得到这份报表的话,就可能需要关联员工基本信息表、公司组织结构表等表格,才能够查询到用户所需要的内容。为此,就需要利用Join语句,把这些表格关联起来。为了提高数据库的查询效率,这些用来关联的字段,最好能够建立rxdxh。这可以显著的提高查询的速度。

 

建议四:在表的更新速度与查询速度之间寻求一个平衡点

 

众所周知,rxdxh本身并不影响数据库的使用,其主要是为了提高Oracle数据库的查询效率。但是,由于当数据库的表中的数据更新的时候,包括记录的增加、删除、更改等等,都会对虽有的rxdxh进行更新。

 

很明显,rxdxh虽然可以提高查询速度。但是,也会对一些表的更新操作产生不良的影响。当在表中建立的rxdxh越多,这个不利影响也会越大。故Oracle数据库管理员在设置rxdxh的时候,还需要注意,在这两个之间需要一个均衡点。

  按照一般的理论来说,当某个表多数用来查询、更新相对来说比较上的话,则要多多采用rxdxh。相反,当某个表记录更新居主导,查询相对来说比较少的话,则不要建立太多的rxdxh,避免对更新的速度差生不利影响。在实际工作中,lyc个表频繁的被视图所调用的话,则最好就好设置比较多的rxdxh了。
CSS中div滚动条样式如何设置

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。