- 浏览: 58343 次
- 性别:
- 来自: 杭州
文章分类
最新评论
区别
主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。
主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。
唯一性索引列允许空值,而主键列不允许为空值。
主键列在创建时,已经默认为空值 + 唯一索引了。
主键可以被其他表引用为外键,而唯一索引不能。
一个表最多只能创建一个主键,但可以创建多个唯一索引。
主键更适合那些不容易更改的唯一标识,如自动递增列、身份证号等。
在 RBO 模式下,主键的执行计划优先级要高于唯一索引。 两者可以提高查询的速度。
-- 创建一张仅包含主键和唯一索引的表
CREATE TABLE test
(PrimaryKey VARCHAR2(20),
UniqueKey VARCHAR2(20)
);
-- 分别创建主键和唯一索引,语法不同
ALTER TABLE test ADD CONSTRAINT test_PrimaryKey PRIMARY KEY (PrimaryKey);
CREATE UNIQUE INDEX test_UniqueKey ON test (UniqueKey);
-- 在 USER_INDEXES 中可以看到两个索引名称
SELECT table_name,table_type,index_name,index_type,uniqueness
FROM USER_INDEXES
WHERE TABLE_NAME='TEST';
-- 在 USER_IND_COLUMNS 中可以看到两个索引字段名称
SELECT table_name,index_name,column_name,column_position
FROM USER_IND_COLUMNS
WHERE TABLE_NAME='TEST';
-- 在 USER_CONSTRAINTS 仅可以看到主键约束名称
SELECT table_name,constraint_name,constraint_type
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST';
-- 在 USER_CONS_COLUMNS 仅可以看到主键约束字段名称
SELECT table_name,constraint_name,column_name,position
FROM USER_CONS_COLUMNS
WHERE CONSTRAINT_NAME IN (SELECT CONSTRAINT_NAME
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST');
-- 为唯一索引增加一个非空约束
ALTER TABLE test MODIFY UniqueKey NOT NULL;
-- 在 USER_CONSTRAINTS 仅可以看到主键约束名称和非空约束名称
SELECT table_name,constraint_name,constraint_type
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST'
-- 在 USER_CONS_COLUMNS 仅可以看到主键约束字段名称和非空约束字段名称
SELECT table_name,constraint_name,column_name,position
FROM USER_CONS_COLUMNS
WHERE CONSTRAINT_NAME IN (SELECT CONSTRAINT_NAME
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST')
谢谢 http://blog.csdn.net/baoqiangwang/article/details/4832814 的分享。
主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。
主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。
唯一性索引列允许空值,而主键列不允许为空值。
主键列在创建时,已经默认为空值 + 唯一索引了。
主键可以被其他表引用为外键,而唯一索引不能。
一个表最多只能创建一个主键,但可以创建多个唯一索引。
主键更适合那些不容易更改的唯一标识,如自动递增列、身份证号等。
在 RBO 模式下,主键的执行计划优先级要高于唯一索引。 两者可以提高查询的速度。
-- 创建一张仅包含主键和唯一索引的表
CREATE TABLE test
(PrimaryKey VARCHAR2(20),
UniqueKey VARCHAR2(20)
);
-- 分别创建主键和唯一索引,语法不同
ALTER TABLE test ADD CONSTRAINT test_PrimaryKey PRIMARY KEY (PrimaryKey);
CREATE UNIQUE INDEX test_UniqueKey ON test (UniqueKey);
-- 在 USER_INDEXES 中可以看到两个索引名称
SELECT table_name,table_type,index_name,index_type,uniqueness
FROM USER_INDEXES
WHERE TABLE_NAME='TEST';
-- 在 USER_IND_COLUMNS 中可以看到两个索引字段名称
SELECT table_name,index_name,column_name,column_position
FROM USER_IND_COLUMNS
WHERE TABLE_NAME='TEST';
-- 在 USER_CONSTRAINTS 仅可以看到主键约束名称
SELECT table_name,constraint_name,constraint_type
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST';
-- 在 USER_CONS_COLUMNS 仅可以看到主键约束字段名称
SELECT table_name,constraint_name,column_name,position
FROM USER_CONS_COLUMNS
WHERE CONSTRAINT_NAME IN (SELECT CONSTRAINT_NAME
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST');
-- 为唯一索引增加一个非空约束
ALTER TABLE test MODIFY UniqueKey NOT NULL;
-- 在 USER_CONSTRAINTS 仅可以看到主键约束名称和非空约束名称
SELECT table_name,constraint_name,constraint_type
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST'
-- 在 USER_CONS_COLUMNS 仅可以看到主键约束字段名称和非空约束字段名称
SELECT table_name,constraint_name,column_name,position
FROM USER_CONS_COLUMNS
WHERE CONSTRAINT_NAME IN (SELECT CONSTRAINT_NAME
FROM USER_CONSTRAINTS
WHERE TABLE_NAME='TEST')
谢谢 http://blog.csdn.net/baoqiangwang/article/details/4832814 的分享。
发表评论
-
Oracle 直接操作一个字符的自增
2013-12-17 09:03 531新增一条语句,其中一个字段是每个月自增。例如:SP+20131 ... -
Oracle 触发器和自增
2013-12-17 09:03 504create sequence eos_serviceitem ... -
Oracle 创建表空间和临时表空间 创建用户
2017-07-18 17:30 368---修改表空间大小 alter database data ... -
Oracle 数据库的操作 截取字符 系统时间
2013-12-17 08:55 759截取前面为0的字符 select ltrim(substr( ... -
orale 创建表空间
2013-09-05 17:47 519---qns 临时表空间 create temporary t ... -
创建视图
2013-03-18 09:15 639如果需要查询数据,且查询的数据在几个表,这个几个表没外键关联, ... -
日期类型转换(3)
2013-01-25 15:26 655三. 字符函数(可用于字面字符或数据库列) 1,字符串截取 ... -
日期类型转换(2)
2013-01-25 15:24 77011 select to_char(sysd ... -
日期类型转换(1)
2013-01-25 15:23 631ORACLE日期时间函数大全 ORACLE日期时间函数大全 ... -
索引的操作
2012-08-09 15:24 690索引的用处: 建 ... -
case 的操作
2012-07-04 09:01 655select i.id, i.managebodyno, i. ... -
创建表和表的自增
2012-03-05 10:25 811-- 创建表(联合主键) -- serviceid 是用于自增 ... -
主键约束、唯一性约束、检查约束
2012-02-29 15:27 27701.约束定义了必须遵循的的用户维护数据一致性和正确性的规则,是 ... -
char, varchar 和 varchar2的区别
2012-02-29 10:47 775区别: 1.CHAR的长度是固定的,而VARCHAR2 ... -
Integer 和Number的区别
2012-02-29 10:27 1991建表的时候,如果是浮点数,一般设置为 number(m,n ) ... -
创建主键的自增
2012-02-29 10:28 710create table serviceitems( serv ...
相关推荐
goldengate同步无主键无唯一索引表的问题以及解决方案.docx
mysql主键和唯一索引的区别(csdn)————程序
1、 主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。 2、 主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。 3、 唯一性索引列允许空值,而主键列不允许为空值。 4、 主键列在创建时...
下面是主键和索引的一些区别与联系。 1. 主键一定是唯一性索引,唯一性索引并不一定就是主键。 所谓主键就是能够唯一标识表中某一行的属性或属性组,一个表只能有一个主键,但可以有多个候选索引。因为主键可以唯一...
OracleGoldenGate针对表没有主键或唯一索引的解决方案[归类].pdf
INFA技术超群_中文KB_00009_PWX_如何实现无主键和唯一索引目标表的数据同步
总结,对于主键与唯一索引约束: • 执行insert和update时,会触发约束检查 • InnoDB违反约束时,会回滚对应SQL • MyISAM违反约束时,会中断对应的SQL,可能造成不符合预期的结果集 • 可以使用 insert … on ...
goldengate同步无主键无唯一索引表的问题以及解决方案-更新关于附加日志.docx
答:拿主键可以唯一确定一条数据,它和物理存储排序一致,不能为空,一个表只能有一个。 原本没有创建的主键的表在磁盘上存储为: Id=0;username=username0;sex=男;address=浙江; Id=1;username=username1;sex=女;...
创建学员信息表--创建唯一索引--修改学员信息表添加主键和检查约束
在MySQL里,主键索引和辅助索引分别是什么意思,有什么区别? 上次的分享我们介绍了聚集索引和非聚集索引的区别,本次我们继续介绍主键索引和辅助索引的区别。 1、主键索引 主键索引,简称主键,原文是PRIMARY KEY,...
LNH_MySQL 18-主键-唯一-普通索引创建及删除小结.mp4
主键和唯一约束都要求字段值唯一,除此外,它们还有如下区别: ·同一张表只能有一个主键,但能有多个唯一约束; ·主键字段值不能为NULL,唯一约束字段值可以为NULL; ·主键字段可以做为其他表的外键,唯一约束...
视图索引存储过程 事务显示事务 隐式事务 --索引 作用:提高查询效率 降低新增修改和删除的效率 --主键索引 唯一索引 聚集索引非聚集索引 --创建索引 --索引index 默认创建的是不唯一,非聚集索引
o主键索引:一种特殊的唯一索引,不允许有空值。 o普通索引:MySQL中基本索引类型,允许空值和重复值。 o联合索引:多个字段创建的索引,使用时遵循最左前缀原则。 o唯一索引:索引列中的值必须是唯一的,但是允许为...
2、业务代码能保证不会写入两个重复的身份证号(如果业务无法保证,可以依赖数据库的唯一索引来进行约束) 3、常用SQL查询语句:SELECT name FROM CUser WHERE id_card = ‘XXX’ 4、建立索引 身份证号比较大,...
INFA技术超群_中文KB_00021_PWC_如何调用存储过程
上面的name和id字段组合起来就是你test表的复合主键 ,它的出现是因为你的name字段可能会出现重名,所以要加上ID字段这样就可以保证你记录的唯一性 ,一般情况下,主键的字段长度和字段数目要越少越好 。 这里就会...
表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。
创建索引会占用额外的存储空间,并且在插入、更新和删除数据时,需要维护索引的结构,这会带来一定的性能开销。 2. 主键(Primary Key): 主键是数据库表中用于唯一标识每一行数据的列或一组列。主键的值不能重复...