GaussDB 约束的语法

1 约束的作用

约束是作用于数据表中列上的规则 ,用于限制表中数据的类型 。约束的存在保证了数据库中数据的精确性和可靠性。约束有列级和表级之分,列级约束作用于单一的列,而表级约束作用于整张数据表。下面是 GaussDB SQL 中常用的约束。

  • NOT NULL 约束:保证列中数据不能有 NULL 值
  • DEFAULT 约束:提供该列数据未指定时所采用的默认值
  • UNIQUE 约束:保证列中的所有数据各不相同
  • 主键约束:唯一标识数据表中的行/记录
  • 外键约束:唯一标识其他表中的一条行/记录
  • CHECK 约束:此约束保证列中的所有值满足某一条件
  • 索引:用于在数据库中快速创建或检索数据

约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。

2 创建约束

当使用CREATE TABLE语句创建表时,或者在使用ALTER TABLE语句创建表之后,可以指定约束。

语法

复制代码
CREATE TABLE table_name
(
     column_name1 data_type size constraint_name,
     column_name2 data_type size constraint_name,
     column_name3 data_type size constraint_name,

    ..............
);

3 删除约束

任何现有约束都可以通过在 alter table 命令中指定 drop constraint 选项的方法删除掉。

例如,要去除 employees 表中的主键约束,可以使用下述命令:

复制代码
alter table employees drop constraint employees_pk;

一些数据库实现可能提供了删除特定约束的快捷方法。

例如,要在gaussdb中删除一张表的主键约束,可以使用如下命令:

复制代码
alter table employees drop primary key;

某些数据库实现允许禁用约束。这样与其从数据库中永久删除约束,你可以只是临时禁用掉它,过一段时间后再重新启用。

4 完整性约束

完整性约束用于保证关系型数据库中数据的精确性和一致性。对于关系型数据库来说,数据完整性由参照完整性(referential integrity,RI)来保证。有很多种约束可以起到参照完整性的作用,这些约束包括主键约束(Primary Key)、外键约束(Foreign Key)、唯一性约束(Unique Constraint)以及上面提到的其他约束。

5 批注

约束的种类有很多,通过约束我们可以让进入数据库的数据更加规范,虽然这样做会很麻烦,有时候甚至还可能影响用户体验,但是还是建议尽量让你的数据库设计的更加规范,只有数据规范了,在之后的数据处理过程中或数据查询分析过程中才会更加高效。本节主要介绍语法部分,下一节会着重介绍各个约束的使用方法。

相关推荐
码农阿豪1 小时前
KingbaseES数据库增删改查操作分享
数据库·oracle
言之。1 小时前
Django REST框架核心:GenericAPIView详解
数据库·python·django
DemonAvenger1 小时前
MySQL存储引擎深度对比:InnoDB vs MyISAM及其应用场景解析
数据库·mysql·性能优化
paid槮2 小时前
MySQL的简单介绍
数据库·mysql
不羁。。10 小时前
【撸靶笔记】第八关:GET - Blind - Boolian Based - Single Quotes
数据库·sql·mybatis
AwhiteV11 小时前
利用图数据库高效解决 Text2sql 任务中表结构复杂时占用过多大模型上下文的问题
数据库·人工智能·自然语言处理·oracle·大模型·text2sql
m0_5951998511 小时前
Redis(以Django为例,含具体操作步骤)
数据库·redis·缓存
爱尚你199311 小时前
MySQL 三大日志:redo log、undo log、binlog 详解
数据库·mysql
小猿姐13 小时前
KubeBlocks AI:AI时代的云原生数据库运维探索
数据库·人工智能·云原生·kubeblocks
NocoBase14 小时前
10 个开源工具,快速构建数据应用
数据库·低代码·开源