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 批注

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

相关推荐
小钻风336625 分钟前
IDEA连接redis数据库时出现Failed to connect to any host resolved for DNS name.
数据库
ulias21231 分钟前
单元最短路问题
数据库·c++·算法·动态规划
安卓开发者33 分钟前
鸿蒙NEXT中SQLite数据库全面实战指南
数据库·sqlite·harmonyos
xuejianxinokok1 小时前
PostgreSQL 18 新功能:虚拟生成列
数据库·后端
DemonAvenger2 小时前
MySQL索引失效全解析:从分析到优化,10年经验实战分享
数据库·mysql·性能优化
咖啡Beans2 小时前
踩坑无数!MySQL UNION和ORDER BY混用的血泪教训,看完不再翻车
数据库·mysql
椰椰椰耶2 小时前
[Spring Cloud][3]从零开始简单工程搭建实践详解,远程调用
java·数据库·spring cloud
时序数据说2 小时前
物联网时序数据库IoTDB是什么?
大数据·数据库·物联网·时序数据库·iotdb
范纹杉想快点毕业2 小时前
请创建一个视觉精美、交互流畅的进阶版贪吃蛇游戏
数据库·嵌入式硬件·算法·mongodb·游戏·fpga开发·交互
时序数据说3 小时前
时序数据库:定义与基本特点
大数据·数据库·物联网·时序数据库