`
m635674608
  • 浏览: 5031340 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

唯一索引与主键索引的比较

 
阅读更多

唯一索引
唯一索引不允许两行具有相同的索引值。
如果现有数据中存在重复的键值,则大多数数据库都不允许将新创建的唯一索引与表一起保存。当新数据将使表中的键值重复时,数据库也拒绝接受此数据。例如,用户表中的身份证(idcard) 列上创建了唯一索引,则所有身份证不能重复

 

主键索引
主键索引是唯一索引的特殊类型。
数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。该列称为表的主键。
在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。

 

比较:
1对于主健/unique constraint , oracle/sql server/mysql等都会自动建立唯一索引;
2主键不一定只包含一个字段,所以如果你在主键的其中一个字段建唯一索引还是必要的;
3主健可作外健,唯一索引不可;
4主健不可为空,唯一索引可;
5主健也可是多个字段的组合;
6主键与唯一索引不同的是:
(1).有not null属性;
(2).每个表只能有一个。

 

索引的注意事项
1.组合或者引用关系的子表(数据量较大的时候),需要在关联主表的列上建立非聚集索引(如订单明细表中的产品ID字段、订单明细表中关联的订单ID字段)

2.索引键的大小不能超过900个字节,当列表的大小超过900个字节或者若干列的和超过900个字节时,数据库将报错。

3.表中如果建有大量索引将会影响INSERT、UPDATE和DELETE语句的性能,因为在表中的数据更改时,所有的索引都将必须进行适当的调整。需要避免对经常更新的表进行过多的索引,并且索引应保持较窄,就是说:列要尽可能的少。

4.为经常用于查询的谓词创建索引,如用于下拉参照快速查找的code、name等。在平台现有下拉参照的查询sql语句中的like条件语句要改成不带前置通配符。还有需要关注Order By和Group By谓词的索引设计,Order By和Group By的谓词是需要排序的,某些情况下为Order By和Group By的谓词建立索引,会避免查询时的排序动作。

4.对于内容基本重复的列,比如只有1和0,禁止建立索引,因为该索引选择性极差,在特定的情况下会误导优化器做出错误的选择,导致查询速度极大下降。

5.当一个索引有多个列构成时,应注意将选择性强的列放在前面。仅仅前后次序的不同,性能上就可能出现数量级的差异。

6.对小表进行索引可能不能产生优化效果,因为查询优化器在遍历用于搜索数据的索引时,花费的时间可能比执行简单的表扫描还长,设计索引时需要考虑表的大小。记录数不大于100的表不要建立索引。频繁操作的小数量表不建议建立索引(记录数不大于5000条)

 
 
 
http://www.cnblogs.com/joshua317/p/5041111.html
分享到:
评论

相关推荐

    主键索引与唯一索引的区别

    1、 主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。 2、 主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。 3、 唯一性索引列允许空值,而主键列不允许为空值。 4、 主键列在创建时...

    goldengate同步无主键无唯一索引表的问题以及解决方案.docx

    GoldenGate 同步无主键无唯一索引表的问题及解决方案 在数据同步中,无主键无唯一索引表的同步问题是常见的困扰, GoldenGate 作为一款优秀的数据同步工具,也遇到了这个问题。因此,本文将讨论 GoldenGate 同步无...

    MySQL 主键与索引的联系与区别分析

    主键一定是唯一性索引,唯一性索引并不一定就是主键。 所谓主键就是能够唯一标识表中某一行的属性或属性组,一个表只能有一个主键,但可以有多个候选索引。因为主键可以唯一标识某一行记录,所以可以确保执行数据...

    MySQL索引之主键索引

    在InnoDB存储引擎中,主键索引被用作聚集索引,这意味着数据行的物理顺序与主键索引的逻辑顺序相同。遵循以下原则设计主键能提高性能: - 自增属性:常选择无业务意义的自增整数列作为主键,如`auto_increment`,...

    数据库,索引,主键,约束,sql

    在数据库中,索引、主键和约束是至关重要的概念,而SQL(Structured Query Language)则是与数据库交互的语言。 首先,索引是提高数据库查询速度的关键工具。它们类似于书籍的目录,使得数据库能够快速定位到特定的...

    OracleGoldenGate针对表没有主键或唯一索引的解决方案[归类].pdf

    Oracle GoldenGate 针对表没有主键或唯一索引的解决方案 Oracle GoldenGate 是一种 数据复制和集成工具,用于在不同的数据库管理系统之间复制和集成数据。然而,在使用 Oracle GoldenGate 复制事务数据时,如果表...

    MySQL的主键与唯一索引约束

    MySQL中的主键与唯一索引约束是数据库设计中至关重要的概念,它们确保数据的唯一性和完整性。主键是一种特殊的唯一索引,它定义了一个表的唯一标识,不允许有重复值且不能为空。唯一索引则允许有空值,但索引中的每...

    oracle创建表创建唯一索引

    以下将详细介绍如何创建学员信息表,创建唯一索引,以及如何修改表来添加主键和检查约束。 首先,我们来理解"创建学员信息表"。在Oracle中,我们可以使用`CREATE TABLE`语句来创建新的表。一个典型的学员信息表可能...

    mysql主键和唯一索引的区别(csdn)————程序.pdf

    因此,唯一索引允许出现NULL值,这是它与主键的一个显著区别。你可以为一张表创建多个唯一索引,以优化不同查询的性能。例如,如果某个不是主键的列经常用于搜索,设置唯一索引可以提高查询速度。 创建主键时,...

    简单例子理解主键,索引,聚集索引,复合索引,非聚合索引

    一、 创建主键(主键=主键索引=聚集索引) 主键是什么? 答:拿主键可以唯一确定一条数据,它和物理存储排序一致,不能为空,一个表只能有一个。 原本没有创建的主键的表在磁盘上存储为: Id=0;username=username0;sex...

    聚簇索引与主键的选择

    聚簇索引与主键的选择一、什么是聚簇索引?二、什么是非聚簇索引?1. InnoDB引擎中2. MyISAM引擎中三、聚簇索引的优劣与主键选择的关系 一、什么是聚簇索引? 首先,聚簇索引不是一种单独的索引类型,其实是数据的...

    SQLSERVER聚集索引和主键(Primary Key)的误区认识

    主键可以基于聚集索引或非聚集索引,而聚集索引不一定与主键有关联。理解这些基本概念对于优化查询性能、设计高效数据库结构以及确保数据完整性至关重要。在数据库设计时,应谨慎选择主键类型和索引类型,以适应特定...

    如何在oracle中查询所有用户表的表名、主键名称、索引、外键等

    与查询主键信息类似,这里通过 `constraint_type = 'U'` 来筛选出唯一性约束。这可以帮助我们了解哪些列是具有唯一性的,这对于理解表结构至关重要。 ### 4. 查询所有用户表的外键信息 #### SQL 语句: ```sql -- ...

    Mysql数据库索引创建、索引删除、索引失效场景详解

    但是,需要注意的是,如果索引与主键关联,必须先删除主键,再删除主键索引。 索引的失效场景包括:更新或删除索引列,使用不带索引的全表扫描操作,使用`SELECT *`而不是明确列出索引列,使用`NOT IN`、`<> ALL()`...

    数据库索引设计和优化

    1. 主键与唯一索引:主键索引是确保表中每条记录唯一性的关键,通常自动创建。唯一索引则限制列中的值不能重复,但不一定是主键。 2. 复合索引:当多个列共同决定查询效率时,可以创建复合索引,即包含多个列的索引...

    SQL Server 索引结构及其使用(聚集索引与非聚集索引)

    "SQL Server 索引结构及其使用(聚集索引与非聚集索引)" 数据库索引是数据库性能优化的关键技术之一。SQL Server 提供了两种索引:聚集索引(clustered index)和非聚集索引(nonclustered index)。本文将详细介绍...

    索引介绍聚集索引和非聚集索引

    - 当表的主键是唯一的自然键时,使用聚集索引非常有效。 ##### 非聚集索引 1. **定义**:非聚集索引是独立于表数据之外的一种数据结构,它不改变表中数据行的物理存储顺序。非聚集索引维护了一个索引键值和指向...

    MySQL索引类型大汇总

    唯一索引与普通索引类似,唯一的区别是索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。可以通过以下三种方式创建唯一索引: * 创建索引:`CREATE UNIQUE INDEX indexName ON mytable...

Global site tag (gtag.js) - Google Analytics