保障数据完整性:深入解析Oracle数据库的主键和外键约束
主键和外键约束:主键约束用于唯一标识数据库表中的每一行数据。一个表只能有一个主键,且主键值不能为NULL。示例:
CREATE TABLE Customers ( CustomerID INT PRIMARY KEY, CustomerName VARCHAR(50) );
外键约束用于确保表与其他表之间的关系的完整性。外键是一个表中的列,其值必须与另一个表中的主键或唯一键相匹配。示例:
CREATE TABLE Orders ( OrderID INT PRIMARY KEY, CustomerID INT, OrderDate DATE, FOREIGN KEY (CustomerID) REFERENCES Customers(CustomerID) );
唯一性约束:唯一性约束用于确保数据库表中的某个列的值是唯一的。示例:
CREATE TABLE Employees ( EmployeeID INT PRIMARY KEY, EmployeeName VARCHAR(50), Email VARCHAR(50) UNIQUE );
默认值和非空约束:默认值约束用于为表中的某个列指定一个默认值。示例:
CREATE TABLE Students ( StudentID INT PRIMARY KEY, StudentName VARCHAR(50), Grade CHAR(1) DEFAULT 'A' );
非空约束用于确保某个列不接受NULL值。示例:
CREATE TABLE Products ( ProductID INT PRIMARY KEY, ProductName VARCHAR(50) NOT NULL, Price DECIMAL(10, 2) );
CHECK约束:CHECK约束用于定义在插入或更新数据时必须满足的条件。示例:
CREATE TABLE Orders ( OrderID INT PRIMARY KEY, OrderDate DATE, TotalAmount DECIMAL(10, 2), CHECK (TotalAmount > 0) );
数据类型约束:数据类型约束用于确保列中的数据与所定义的数据类型相匹配。示例:
CREATE TABLE Students ( StudentID INT PRIMARY KEY, StudentName VARCHAR(50), Age INT CHECK (Age >= 0) );
检查约束:检查约束允许在列级别定义一个条件,确保插入或更新的数据满足指定的条件。可以使用布尔表达式、比较运算符和函数来定义检查约束。示例:
CREATE TABLE Employees ( EmployeeID INT PRIMARY KEY, EmployeeName VARCHAR(50), Salary DECIMAL(10, 2), CONSTRAINT CHK_Salary CHECK (Salary > 0) );
级联约束:级联约束是外键约束的一种扩展,用于在主表的行被删除或更新时自动处理相关的从表行。可以指定级联删除或级联更新操作来维护数据一致性。示例:
CREATE TABLE Customers ( CustomerID INT PRIMARY KEY, CustomerName VARCHAR(50) ); CREATE TABLE Orders ( OrderID INT PRIMARY KEY, CustomerID INT, OrderDate DATE, FOREIGN KEY (CustomerID) REFERENCES Customers(CustomerID) ON DELETE CASCADE );
来自约束:来自约束("FROM" constraints)是一种基于表达式的约束,它可以通过一个查询来定义约束条件。它允许将查询结果用作约束条件。示例:
CREATE TABLE Employees ( EmployeeID INT PRIMARY KEY, EmployeeName VARCHAR(50), DepartmentID INT, Salary DECIMAL(10, 2), CONSTRAINT CHK_Salary CHECK (Salary > (SELECT AVG(Salary) FROM Employees)) );
域约束:域约束用于定义特定列的有效值范围,它使用预定义的域(domain)来限制数据输入。示例:
CREATE DOMAIN AgeDomain AS INT CHECK (VALUE >= 0 AND VALUE