SQL Server 的五种约束类型
在SQL Server中,约束是用于强制数据完整性的规则,确保数据库中数据的准确性和一致性。以下是五种主要的约束类型及其作用。
主键约束(PRIMARY KEY)
主键约束用于唯一标识表中的每一行数据,确保列或列组合中的值唯一且不为空。一个表只能有一个主键约束。
示例代码:
sql
CREATE TABLE Employees (
EmployeeID INT PRIMARY KEY,
Name VARCHAR(50) NOT NULL
);
外键约束(FOREIGN KEY)
外键约束用于建立表之间的关系,确保引用另一个表的主键或唯一键的列的值必须存在于被引用的表中。
示例代码:
sql
CREATE TABLE Orders (
OrderID INT PRIMARY KEY,
EmployeeID INT,
FOREIGN KEY (EmployeeID) REFERENCES Employees(EmployeeID)
);
唯一约束(UNIQUE)
唯一约束确保列或列组合中的值唯一,但与主键约束不同,唯一约束允许空值(NULL)。
示例代码:
sql
CREATE TABLE Customers (
CustomerID INT PRIMARY KEY,
Email VARCHAR(100) UNIQUE
);
检查约束(CHECK)
检查约束用于限制列中的值的范围,确保数据满足指定的条件。
示例代码:
sql
CREATE TABLE Products (
ProductID INT PRIMARY KEY,
Price DECIMAL(10,2) CHECK (Price > 0)
);
缺省约束(DEFAULT)
却省约束用于为列指定默认值,当插入数据时如果未提供该列的值,则使用默认值。
示例代码:
sql
CREATE TABLE Orders (
OrderID INT PRIMARY KEY,
OrderDate DATE DEFAULT GETDATE()
);
总结
SQL Server的五种约束类型(主键、外键、唯一、检查、缺省)为数据完整性提供了强大的保障。合理使用这些约束可以有效避免数据冗余和不一致,确保数据库的可靠性和准确性。