广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >GBase 8s数据库主键约束、唯一约束和唯一索引的区别解析
  • 212
分享到

GBase 8s数据库主键约束、唯一约束和唯一索引的区别解析

2024-04-02 19:04:59 212人浏览 薄情痞子
摘要

主键约束(PRIMARY KEY) 主键用于唯一地标识表中的每一条记录,可以定义一列或多列为主键,一个表上仅只能有一个主键;不建议更新主键;主键列上没有任何两行具有相同值(即重复值)

主键约束(PRIMARY KEY)

  1. 主键用于唯一地标识表中的每一条记录,可以定义一列或多列为主键,一个表上仅只能有一个主键;
  2. 不建议更新主键;
  3. 主键列上没有任何两行具有相同值(即重复值),且不允许空(NULL);
  4. 主健可作外健,唯一索引不可;

唯一性约束(UNIQUE)

  1. 唯一性约束用来限制不受主键约束的列上的数据的唯一性,用于作为访问某行的可选手段,一个表上可以放置多个唯一性约束;
  2. 只要唯一就可以更新;
  3. 表中任意两行在指定列上都不允许有相同的值,但允许空(NULL);

唯一索引(UNIQUE INDEX)

  1. 唯一索引可以确保任何生成重复键值的尝试都会失败;
  2. 只要唯一就可以更新;
  3. 表中任意两行在指定列上都不允许有相同的值,但允许空(NULL);

唯一性约束和主键约束的区别:

  1. 唯一性约束允许在该列上存在NULL值,而主键约束的限制更为严格,不但不允许有重复,而且也不允许有空值。

唯一约束和唯一索引的区别:

前者是用来检查数据的正确性,后者用来实现数据查询的优化,目的不同。
唯一性约束与唯一索引有所不同:

  • 创建唯一约束会在GBase 8s中创建一个constraint,同时也会创建一个该约束对应的唯一索引;
  • 创建唯一索引只会创建一个唯一索引,不会创建constraint;

也就是说其实唯一约束是通过创建唯一索引来实现的。

以下示例来说明这三者之间的区别:
1,创建表、导入基础数据

drop table if exists tab1;
create table tab1(col1 int, col2 varchar(20), col3 varchar(20));
insert into tab1 values(1,'test001','test001');
insert into tab1 values(2,null,'test002');
insert into tab1 values(3,'test003',null);

2,创建主键、唯一约束和唯一索引
主键唯一值且不允许为null,唯一约束值唯一但允许null,唯一索引值唯一但允许null

alter table tab1 add constraint primary key(col1) constraint pk_tab1_col1;
alter table tab1 add constraint unique(col2) constraint uk_tab1_col2;
create unique index ux_tab1_col3 on tab1 (col3);

查看表的报告,可以看到三个索引(对应主键、唯一约束和唯一索引),但需要注意的是主键、唯一约束的索引名称并不是指定的约束名称

oncheck -pt testdb:tab1 | grep 'fragment partition'

Index  102_3 fragment partition datadbs01 in DBspace datadbs01
Index  102_4 fragment partition datadbs01 in DBspace datadbs01
Index ux_tab1_col3 fragment partition datadbs01 in DBspace datadbs01

3,测试区别

insert into tab1 values(null,'test004','test004');

将报错误:703: Primary key on table (tab1) has a field with a null key value.
不允许空值。

insert into tab1 values(3,'test005','test005');

将报错误:268: Unique constraint (gbasedbt.pk_tab1_col1) violated.
违反主键约束(pk_tab1_col1),因已经存在值 3 。

insert into tab1 values(4,null,'test006');

将报错误:268: Unique constraint (gbasedbt.uk_tab1_col2) violated.
违反唯一约束(uk_tab1_col2),因已经存在值 null 。

insert into tab1 values(5,'test003','test007');

将报错误:268: Unique constraint (gbasedbt.uk_tab1_col2) violated.
违反唯一约束(uk_tab1_col2),因已经存在值 test003 。

insert into tab1 values(6,'test008',null);

将报错误:239: Could not insert new row - duplicate value in a UNIQUE INDEX column (Unique Index:ux_tab1_col3).
不允许插入重复值,因已经存在值 null 。

insert into tab1 values(7,'test009','test002');

将报错误:239: Could not insert new row - duplicate value in a UNIQUE INDEX column (Unique Index:ux_tab1_col3).
不允许插入重复值,因已经存在值 test002 。

insert into tab1 values(8,'test010','test010');

插入成功。

alter table tab1 drop constraint uk_tab1_col2;
oncheck -pt testdb:tab1 | grep 'fragment partition'
Index  102_3 fragment partition datadbs01 in DBspace datadbs01
Index ux_tab1_col3 fragment partition datadbs01 in DBspace datadbs01

删除约束,对应的索引一并删除。

细心的你,会发现:

  1. 如果字段加上not null约束,再加上唯一约束或者唯一索引,功能上将等同于主键约束;
  2. 唯一约束仅仅比唯一索引多了一个约束;

到此这篇关于GBase 8s数据库主键约束、唯一约束和唯一索引的区别的文章就介绍到这了,更多相关GBase 8s数据库主键内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: GBase 8s数据库主键约束、唯一约束和唯一索引的区别解析

本文链接: https://www.lsjlt.com/news/139736.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • GBase 8s数据库主键约束、唯一约束和唯一索引的区别解析
    主键约束(PRIMARY KEY) 主键用于唯一地标识表中的每一条记录,可以定义一列或多列为主键,一个表上仅只能有一个主键;不建议更新主键;主键列上没有任何两行具有相同值(即重复值)...
    99+
    2022-11-13
  • 数据库主键约束、唯一约束和唯一索引的区别是什么
    本篇内容主要讲解“数据库主键约束、唯一约束和唯一索引的区别是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库主键约束、唯一约束和唯一索引的区别是什么”吧!主键约束(PRIMARY KEY...
    99+
    2023-06-29
  • 浅谈MYSQL主键约束和唯一约束的区别
    目录主键约束唯一约束主键约束 PRIMARY KRY 主键 是唯一的 一张表只能有一个主键 AUTO_INCREMENT 一定要和主键连用 主键一定是非空的 NOT NULL 特点...
    99+
    2022-11-12
  • sql主键约束和唯一约束有什么区别
    主键约束和唯一约束在功能上有一些区别。主键约束:- 主键约束用于定义一个表中的一列或一组列作为主键,用于唯一标识表中的每一行数据。-...
    99+
    2023-10-11
    sql
  • oracle 唯一索引,唯一约束,主键之间的联系
    主键(primary key)是表中的一个或多个字段,它的值用于唯一地标识表中的某一条记录,在两个表的关系中,主键用来在一个表中引用来自于另一个表中的特定记录,,主键时一种唯一关键字,表定义的一部分。一个表...
    99+
    2022-10-18
  • SQLServer中主键和唯一约束的区别是什么
    SQLServer中主键和唯一约束的区别是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先说明一点,主键又称主键约束,它也是一种约束,看...
    99+
    2022-10-18
  • Sequoiadb数据库怎么对主键和唯一索引键相同的表修改存储引擎为Sequoiadb
    本篇内容主要讲解“Sequoiadb数据库怎么对主键和唯一索引键相同的表修改存储引擎为Sequoiadb”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Sequo...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作