DBMS 中的约束,约束强制限制可以从表中插入/更新/删除的数据或数据类型。约束的整个目的是在更新/删除/插入表中时保持数据完整性。在本文中,我们将学习可以在 RDBMS 中创建的几种类型的约束。
约束的类型
- 非空
- 独特
- 默认
- 校验
- 键约束 – 主键,外键
- 域约束
- 映射约束
非空
NOT NULL
约束确保列不保存NULL
值。当我们在将记录插入表时不为特定列提供值时,默认情况下它采用NULL
值。通过指定NULL
约束,我们可以确定特定列不能具有NULL
值。
例:
CREATE TABLE STUDENT(
ROLL_NO INT NOT NULL,
STU_NAME VARCHAR (35) NOT NULL,
STU_AGE INT NOT NULL,
STU_ADDRESS VARCHAR (235),
PRIMARY KEY (ROLL_NO)
);
唯一
UNIQUE
约束强制一列或一组列具有唯一值。如果列具有唯一约束,则意味着特定列不能在表中具有重复值。
CREATE TABLE STUDENT(
ROLL_NO INT NOT NULL,
STU_NAME VARCHAR (35) NOT NULL UNIQUE,
STU_AGE INT NOT NULL,
STU_ADDRESS VARCHAR (35) UNIQUE,
PRIMARY KEY (ROLL_NO)
);
默认
当将记录插入表中时没有提供任何值时,DEFAULT
约束为列提供默认值。
CREATE TABLE STUDENT(
ROLL_NO INT NOT NULL,
STU_NAME VARCHAR (35) NOT NULL,
STU_AGE INT NOT NULL,
EXAM_FEE INT DEFAULT 10000,
STU_ADDRESS VARCHAR (35) ,
PRIMARY KEY (ROLL_NO)
);
检查
此约束用于指定表的特定列的值范围。在列上设置此约束时,它确保指定的列必须具有落在指定范围内的值。
CREATE TABLE STUDENT(
ROLL_NO INT NOT NULL CHECK(ROLL_NO >1000) ,
STU_NAME VARCHAR (35) NOT NULL,
STU_AGE INT NOT NULL,
EXAM_FEE INT DEFAULT 10000,
STU_ADDRESS VARCHAR (35) ,
PRIMARY KEY (ROLL_NO)
);
在上面的例子中,我们在STUDENT
表的ROLL_NO
列上设置了检查约束。现在,ROLL_NO
字段的值必须大于 1000。
键的约束
主键
主键唯一标识表中的每条记录。它必须具有唯一值,并且不能包含空值。在下面的示例中,ROLL_NO
字段被标记为主键,这意味着ROLL_NO
字段不能具有重复值和空值。
CREATE TABLE STUDENT(
ROLL_NO INT NOT NULL,
STU_NAME VARCHAR (35) NOT NULL UNIQUE,
STU_AGE INT NOT NULL,
STU_ADDRESS VARCHAR (35) UNIQUE,
PRIMARY KEY (ROLL_NO)
);
外键
外键是表的列,指向另一个表的主键。它们充当表之间的交叉引用。
在这里了解更多相关信息
域约束
每个表都有一组特定的列,每列基于其数据类型允许相同类型的数据。该列不接受任何其他数据类型的值。
域约束是用户定义的数据类型,我们可以像这样定义它们:
域约束=数据类型+约束(NOT NULL
/ UNIQUE
/ PRIMARY KEY
/ FOREIGN KEY
/ CHECK
/ DEFAULT
)