1. 首页 > 智能数码 >

【数据库】在Oracle中合理创建数据库索引

在Oracle中合理创建数据库的索引

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

【数据库】在Oracle中合理创建数据库索引【数据库】在Oracle中合理创建数据库索引


一 根据表的大小来创建索引

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

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

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

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

二 根据列的特征来创建索引

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

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

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

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

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

三 在一个表上创建多少索引合适?

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

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

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

lishixinzhi/Article/program/Oracle/201311/18407

在数据表中索引有什么用,怎么建立索引

索引用于快速找出在某个列中有一特定值的行,不使用索引,MySQL必须从第一条记录开始读完整个表,直到找出相关的行,表越大,查询数据所花费的时间就越多。建立索引的操作步骤如下:

1、首先我们打开一个要操作的数据表,如下图所示,我们需要给name字段添加索引。

2、接下来我们就可以通过create index来添加索引了,如下图所示,on后面的内容别丢掉了。

3、然后我们展开表下面的索引文件夹,就可以看到创建的索引了。

4、接下来我们在创建索引的时候还可以在字段后面添加排序方式。

5、然后删除索引的时候用的是drop语句,如下图所示,和删除表类似。

6、后执行drop语句以后,在索引文件夹下面就没有了索引。

在sql中,建立索引用的命令是

创建索引的操作,可以使用alter命令或者create命令,其语法如下

alter table 表名 add index 索引名 (column_list) ;

alter table 表名 add unique (column_list) ;

alter table 表名 add primary key (column_list) ;

这三个分别为创建一般索引,索引,主键索引,其中column_list为表的 字段名称,多个字段可以使用逗号隔开。

create的方式创建索引,不能创建主键索引

create index 索引名on 表名 (column_list) ;

create unique index 索引名 on 表名 (column_list) ;

如何建立索引

数据库中的索引分为两种类型,分别是普通索引、索引。下面让我们来分别介绍一下这两种索引。

第一种是普通索引,CREATE INDEX indexName ON mytable(username(length));创建表的时候直接指定。删除索引的语法:DROP INDEX [indexName] ON mytable;

请点击输入图片描述

第二种是索引,它与普通索引是类似的,但也存在不同之处,不同之处在于索引列的值必须,但允许有空值。如果是组合索引,则列值的组合必须。

请点击输入图片描述

请点击输入图片描述

请点击输入图片描述

以上三张图分别为创建索引、修改表结构、创建表时直接指定的数据。而且还有四种方式来添加数据表的索引,下面来分别介绍一下。

第一种方式:ALTER TABLE tbl_name ADD PRIMARY KEY (column_list): 该语句添加一个主键,这意味着索引值必须是的,且不能为NULL。

第二种方法:ALTER TABLE tbl_name ADD UNIQUE index_name (column_list): 这条语句创建索引的值必须是的(除了NULL外,NULL可能会出现多次)。

第三种方法:ALTER TABLE tbl_name ADD INDEX index_name (column_list): 添加普通索引,索引值可出现多次。

第四种方法:ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list):该语句指定了索引为 FULLTEXT ,用于全文索引。

请点击输入图片描述

请点击输入图片描述

END

总结

1创建索引

修改表结构

创建表时直接指定数据

在数据表中索引有什么用?怎么建立索引?

索引是表示数据的另一种方式,它提供的数据顺序不同于数据在磁盘上的物理存储顺序。索引的特殊作用是在表内重新排列记录的物理位置。索引可建立在数据表的一列上,或建立在表的几列的组合上。

索引被创建于已有的表中,它可使对行的定位更快速更有效。可以在表格的一个或者多个列上创建索引,每个索引都会被起个名字。用户无法看到索引,它们只能被用来加速查询。

建立索引的方法:

create [unique][cluster] index <索引名>

on <表名>(<列名>[<次序>][,<列名>][<次序>]?)

索引能够建立在表的一列或多列上。每一个<列名>后面能够用<次序>制定索引值得排列次序。可选ASC(升序)和DESC(降序),缺省值为ASC

unique表明此索引的每个索引值仅仅相应的数据记录。

cluster表示要建立的索引是聚簇索引。所谓聚簇索引指索引项的顺序与表中记录的物理顺序一致的索引组织。

在一个基本表上多仅仅能建立一个聚簇索引。

注释:更新一个包含索引的表需要比更新一个没有索引的表更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常用于搜索的列上面创建索引。

如何为表建立索引?

建立索引的优缺点:

为什么要创建索引呢?

这是因为,创建索引可以大大提高系统的性能。

第一、通过创建性索引,可以保证数据库表中每一行数据的性。

第二、可以大大加快 数据的检索速度,这也是创建索引的主要的原因。

第三、可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。

第四、在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。

第五、通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

也许会有人要问:增加索引有如此多的优点,为什么不对表中的每一个列创建一个索引呢?这种想法固然有其合理性,然而也有其片面性。虽然,索引有许多优点, 但是,为表中的每一个列都增加索引,是非常不明智的。

这是因为,增加索引也有许多不利的一个方面:

第一、创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。

第二、索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间。如果要建立聚簇索引,那么需要的空间就会更大。

第三、当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。

什么样的字段适合创建索引:

索引是建立在数据库表中的某些列的上面。因此,在创建索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索引。

一般来说,应该在这些列上创建索引,例如:

第一、在经常需要搜索的列上,可以加快搜索的速度;

第二、在作为主键的列上,强制该列的性和组织表中数据的排列结构;

第三、在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;

第四、在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;

第五、在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;

第六、在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

建立索引,一般按照select的where条件来建立,比如: select的条件是where f1 and f2,那么如果我们在字段f1或字段f2上索引是没有用的,只有在字段f1和f2上同时建立索引才有用等。

什么样的字段不适合创建索引:

同样,对于有些列不应该创建索引。一般来说,不应该创建索引的的这些列具有下列特点:

第一,对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,

并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。

第二,对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,

在查询的结果中,结果集的数据行占了表中数据行的很 例,即需要在表中搜索的数据行的比例很大。

增加索引,并不能明显加快检索速度。

第三,对于那些定义为text, p_w_picpath和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。

第四,当修改性能远远大于检索性能时,不应该创建索 引。这是因为,修改性能和检索性能是互相矛盾的。

当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。

因此,当修改性能远远大于检索性能时,不应该创建索引。

创建索引的方法::

1、创建索引,例如 create index <索引的名字> on table_name (列的列表);

2、修改表,例如 alter table table_name add index[索引的名字] (列的列表);

3、创建表的时候指定索引,例如create table table_name ( [...], INDEX [索引的名字] (列的列表) );

查看表中索引的方法:

show index from table_name; 查看索引

索引的类型及创建例子::

1.PRIMARY KEY (主键索引)

mysql> alter table table_name add primary key ( `column` )

2.UNIQUE 或 UNIQUE KEY (索引)

mysql> alter table table_name add unique (`column`)

3.FULLTEXT (全文索引)

mysql> alter table table_name add fulltext (`column` )

4.INDEX (普通索引)

mysql> alter table table_name add index index_name ( `column` )

5.多列索引 (聚簇索引)

mysql> alter table `table_name` add index index_name ( `column1`, `column2`, `column3` )

修改表中的索引:

alter table tablename drop primary key,add primary key(fileda,filedb)

数据库建立索引的目的

建立索引的目的是什么

C。【解析】索引是将具有检索意义的事项按照一定方式有序编排起来,以供检索,在数据框中使用索引可大大提高数据库的性能,如查询、更新等。

索引是关系数据库中用于存放每一条记录的一种对象,主要目的是加快数据的读取速度和完整性检查。建立索引是一项技术性要求高的工作。一般在数据库设计阶段的与数据库结构一道考虑。应用系统的性能直接与索引的合理直接有关。

在计算机领域中,建立索引是一种常见的数据结构和算法,用于加快对数据的搜索和访问速度。索引可以将数据进行分类和排序,使得查询和检索变得更加高效和快速。

创建索引的目的是通过索引尽可能找到匹配where条件的行,减少不必要的回表,提高查询效率;需要辩证地看待区分度比较低的字段在组合索引中的作用。

数据库为什么要建索引

1、在计算机领域中,建立索引是一种常见的数据结构和算法,用于加快对数据的搜索和访问速度。索引可以将数据进行分类和排序,使得查询和检索变得更加高效和快速。

2、大部分开发会了解这样的《开发规范》:创建索引要选择区分度高的字段。他们会认为区分度低的字段不适合创建索引或者不适合添加到组合索引里面。但是这样的操作会导致很多慢查。

3、在数据库系统中建立索引主要有以下作用:(1)快速取数据;(2)保证数据记录的性;(3)实现表与表之间的参照完整性;(4)在使用ORDERby、groupby子句进行数据检索时,利用索引可以减少排序和分组的时间。

数据库与数据仓库的区别是什么?

1、数据仓库:是数据库概念的升级。从逻辑上理解,数据库和数据仓库没有区别,都是通过数据库软件实现的存放数据的地方,只不过从数据量来说,数据仓库要比数据库更庞大得多。数据仓库主要用于数据挖掘和数据分析。

2、但是,数据库通常更关注业务交易处理(OLTP),而数据仓库更关注数据分析层面(OLAP),由此产生的数据库模型上也会有很大的异。

3、数据仓库和数据库的主要区别:数据仓库是指从业务数据中创建信息数据库,并针对决策和分析进行优化。数据库是数据管理的有效技术,是由一批数据构成的有序,这些数据被存放在结构化的数据表里。

4、数据仓库是面向市场的,用于知识工人的数据分析。从中我们可以发现数据库和数据仓库的面向对象是不一样的。当然,在数据内容中两者也是有很大的区别的,一般来说数据库管理当前数据。但是一般这种数据比较琐碎,很难用于决策。

5、简而言之,数据库是面向事务的设计,数据仓库是面向主题设计的。数据库一般存储在线交易数据,数据仓库存储的一般是历史数据。

6、)数据挖掘和统计统计也开始支持数据挖掘。

为数据表创建索引的目的是

1、创建索引的目的是通过索引尽可能找到匹配where条件的行,减少不必要的回表,提高查询效率;需要辩证地看待区分度比较低的字段在组合索引中的作用。

2、这是因为,创建索引可以大大提高系统的性能。主要的原因是可以大大加快数据的检索速度;而创建的性索引,可以保证数据库表中每一行数据的性。

3、建立索引的目的是加快对表中记录的查找或排序。建索引可以大大提高系统的性能。

4、SQL创建索引的目的如下:通过性索引(unique)可确保数据的性;加快数据的检索速度;加快表之间的连接;减少分组和排序时间;使用优化隐藏器提高系统性能。

5、不知道这样的例子你能否理解。上面的例子,你可以把汉字的读音、释义、组词等信息看做数据表中多个列中的值。汉字呢就相当于是表中数据的主键值。

索引怎么创建

问题一:索引怎么建立使用 如果你查询的字段都在索引中,那么可以只查询索引,不用查询表,就可以输出数据。

这是建索引时的一种考虑。

但是在你这种情况下不适用。

我猜你是想输出大批数据,而不是根据索引选择有数的那么几条。

输出数据占总数据量达到一定比例以后,再用索引就是浪费更多资源而得不到回报了。

因为数据行存储在块中。一块存多行。用索引时是根据索引信息,每一行访问一次数据块。

数据多了会覆盖大多数数据块,并且一个数据块会被访问多次。就不如全表扫描一次,访问一个叮据块就把该块所有行都输出。这样效率。

所以你这种情况不应该用索引的。

问题二:如何建立主索引 首先有一点你没有弄明白,数据库表才可以建主索引,自由表是不能建主索引的。也就是说数据库表可以建4种索引:主索引、候选索引、普通索引、索引。但自由表只能建立3种索引:候选索引、普通索引、索引。 如果要建主索引,可以在表设计器窗口的“索引”选项卡中建立,但index on 命令中不能建立主索引,此命令只能建候选索引、普通索引和索引。 如:index on 学号 tag 学号 candidate index on 姓名 tag 姓名 unique index on 性别 tag 性别 (上述三个命令分别的是建立候选索引、索引、普通索引) 但create table 命令中可以在指定字段属性的同时建立此字段为主索引,前提也是必须是数据库表。 举个例子:要求创建一个“学生”数据库中的“学籍”表,字段有学号,姓名,成绩,同时指定学号为主索引。 open data 学生 create table 学籍 (学号 C(6) primary key ,姓名 c(8),成绩 n(5,1))

问题三:oracle 数据库如何建立索引 如何用索引? 5分 方法如下:

Oracle中建立索引,会提高查询速度: create index 索引名 on 表名(列名);

例如:

create index index_userid on tbl_detail(userid);

如何找数据库表的主键字段的名称?

SELECT FROM user_constraints WHERE CONSTRAINT_TYPE='P' and table_name='AAA'; select from dba_cons_columns where CONSTRAINT_NAME='SYS_AAA';

Oracle 在创建主键(可以不加constrai浮t SYS_AAA),会为库表自动创建索引,

索引的列为主键列。 并且当库表某些列名或者库表名改变时候,

Oracle自动创建的索引SYS_AAA,中的索引列也会自动更新(类似于视图),并且SYS_AAA会与名字更改后的库表还是保持索引关系。 关键系统库表: desc dba_constraints desc dba_cons_columns

desc dba_indexes desc dba_ind_columns desc DBA_TAB_COLUMNS

例子1:更改库表的列名

ALTER TABLE AAA RENAME COLUMN ID TO AAA_ID; create table AAA ( ID NUMBER(8), NAME CHAR(20),

constraint SYS_AAA primary key(ID) );

查找约束名字

select c.CONSTRAINT_NAME,c.table_name,cc.COLUMN_NAME from user_constraints c, user_cons_columns cc

where c.constraint_name=cc.constraint_name and c.table_name ='AAA' AND C.CONSTRAINT_TYPE='P';

CONSTRAINT_NAME TABLE_NAME COLUMN_NAME ------------------------------ ------------ ------------- SYS_AAA AAA ID

查找索引

select index_name,index_type,uniqueness from user_indexes where table_name='AAA'; INDEX_NAME INDEX_TYPE UNIQUENES

问题四:word中如何建立索引 1.要编入目录的行在有正文字样栏点下拉选项样式里设置成标题.同时也可以更改字题及大小,但要使用样式为标题才可以.如果你在编写WORD文档时使用了标题样式,第一步略.

2.视图用大纲视图方式,打开文档结构视图,用向左向右箭头调整目录大纲级别合适为好.

3.光标移到上面. 4.插入索引和目录,点目录标签.

5.确定,完成.

问题五:如何创建空间索引 into user_sdo_geom_metadata(table_name,COLUMN_NAME, DIMINFO, SRID)

values(

't_city',

'GEOMETRY',

MDSYS.SDO_DIM_ARRAY(

MDSYS.SDO_DIM_ELEMENT('X',-180,180,0.005),

MDSYS.SDO_DIM_ELEMENT('Y',-90,90,0.005)

),

8307

)问题六:sql怎么建立索引 CREATE INDEX

为给定表或视图创建索引。

只有表或视图的所有者才能为表创建索引。表或视图的所有者可以随时创建索引,无论表中是否有数据。可以通过指定限定的数据库名称,为另一个数据库中的表或视图创建索引。

语法

CREATE [ UNIQUE ] [ CLUSTERED | NONCLUSTERED ] INDEX index_name

ON { table | view } ( column [ ASC | DESC ] [ ,...n ] )

[ WITH [ ,...n] ]

[ ON filegroup ]

::=

{ PAD_INDEX |

FILLFACTOR = fillfactor |

IGNORE_DUP_KEY |

DROP_EXISTING |

STATISTICS_NOREPUTE |

SORT_IN_TEMPDB

}--这是基本语法,建立索引,只针对查询和一些更新和删除的速度,像性别一列,如果表里面有1000行,如果只有1行是男,这样用索引的话肯定高,如果有990行是男,那么它不如直接扫描了,这是选择性

问题七:数据库索引有哪几种,怎样建立索引 索引分为聚簇索引和非聚簇索引两种,聚簇索引 是按照数据存放的物理位置为顺序的,而非聚簇索引就不一样了;聚簇索引能提高多行检索的速度,而非聚簇索引对于单行的检索很快。 根据数据库的功能,可以在数据库设计器中创建三种索引:索引、主键索引和聚集索引。 在数据库表中创建的索引可以是是索引、主键索引和聚集索引 景安服务器即使为您解答

问题八:如何创建索引 例如,如果频繁查询 employee 表中(其中主键为 emp_id)的身份证号码 (ssn)列,并希望确保身份证号码是的,则可以在 ssn 上创建索引。如果用户为一个以上的雇员输入相同的身份证号码,则数据库将显示错误而且无法保存该表。在创建或修改索引时,可以可设置一个忽略重复键的选项。如果此选项已设置为“是”,当您试图通过添加影响多行的数据来创建重复键(使用 INSERT 语句)时,则不会添加包含重复项的行;如果此选项设置为“否”,则整个插入操作将失败,并且将回滚所有数据。 创建索引 在对象资源管理器中,右键单击表,再单击“设计”。此时,将在表设计器中打开该表。在表设计器菜单上,单击“索引/键”。单击“添加”。“选定的主/键或索引”列表将显示新索引的系统分配名称。在网格中,单击“类型”。从属性右侧的下拉列表中选择“索引”。在“列”下,选择要编制索引的列。多可选择 16 列。为获得佳的性能,请只为每个索引选择一列或两列。对于所选的每一列,指定索引是以升序还是以降序来排列此列的值。在网格中,单击“是的”。从属性右侧的下拉列表中选择“是”。如果希望忽略会在索引中创建重复键(用 INSERT 语句)的数据,请选择“忽略重复键”选项并选择“是”。在保存表或关系图时将在数据库中创建该索引。注意:如果单个列在多行中包含 NULL,则无法对该列创建索引。同样,如果列的组合在多行中包含 NULL,则无法对多个列创建索引。在进行索引时,它们都被视为重复值。

问题九:怎么创建数据库的索引 打个比方

create table t1(a int);

create index i1 on t1(a);

那么t1表的列a就创建了索引。以后查询t1表,列a有查询条件的时候就可以用到这个索引。

使用索引提高查询效率是数据库自己的事情,一般情况下不需要人为干预索引的使用

问题十:oracle建立索引 对三个字段建立索引:

create index Stuname on student(name);

create index Stusex on student(sex);

create index Stugrade on student(grade);

注意的问题,考虑是不是要建立索引(unique),如果有学号的话,可以考虑建立索引引。

再就是对经常查询,但又相对稳定的可以建立聚簇索引,提高查询效率

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至836084111@qq.com 举报,一经查实,本站将立刻删除。

联系我们

工作日:9:30-18:30,节假日休息