pk:主键是约束,满足条件是非空(not null)而且是唯一(unique)的 。
unique index:索引 主要是可以允许有null,不能有重复。
index :索引 可以为null,可以有重复。
唯一索引和非唯一索引都存储了rowid,唯一索引的rowid是放行头的,非唯一索引把rowid当做一个字段来处理,唯一索引不用记录rowid的长度,唯一索引比非唯一索引少了一个bytes
测试:
SQL> create table ma_test
2 (
3 id number not null,
4 name varchar(50)
5 );
表已创建。
SQL>
SQL> create unique index name_index on ma_test(name);
索引已创建。
SQL>
SQL> insert into ma_test values(1,'mahanso');
已创建 1 行。
SQL> insert into ma_test values(2,'alex');
已创建 1 行。
SQL> insert into ma_test values(3,'mike');
已创建 1 行。
SQL> --违反唯一索引
SQL> insert into ma_test values(4,'mahanso');
insert into ma_test values(4,'mahanso')
*
第 1 行出现错误:
ORA-00001: unique constraint (EMALL_INTERFACE.NAME_INDEX) violated
SQL> --判断唯一索引是否可以为null
SQL> insert into ma_test values(4,'');
已创建 1 行。
SQL> drop index name_index ;
索引已删除。
SQL> drop table ma_test;
表已删除。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12272958/viewspace-677025/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/12272958/viewspace-677025/