SQL 中 CHECK 约束用于在表中定义数据完整性规则,包括:值范围检查:定义列值的范围。唯一性检查:强制列值唯一性。数据类型验证:验证插入值是否属于特定数据类型。条件表达式:包含复杂条件以定义高级验证规则。引用其他列:根据其他列值定义数据完整性。跨表检查:在子表上强制参照完整性。

SQL 中 CHECK 约束的所有用法
CHECK 约束用于在表中定义数据完整性规则,确保插入数据符合特定条件。它有以下几种用法:
1. 值范围检查
可以为列定义值范围,以确保插入的值在该范围内。例如:
CREATE TABLE Employees ( salary DECIMAL(10, 2) CHECK (salary BETWEEN 10000 AND 20000) );
2. 唯一性检查
CHECK 约束可用于强制列值的唯一性,类似于 UNIQUE 约束。例如:
CREATE TABLE Customers ( customer_id INT PRIMARY KEY, email VARCHAR(50) CHECK (UNIQUE(email)) );
3. 数据类型验证
CHECK 约束可以验证插入的值是否属于特定的数据类型。例如:
睿拓智能网站系统-网上商城1.0免费版软件大小:5M运行环境:asp+access本版本是永州睿拓信息专为电子商务入门级用户开发的网上电子商城系统,拥有产品发布,新闻发布,在线下单等全部功能,并且正式商用用户可在线提供多个模板更换,可实现一般网店交易所有功能,是中小企业和个人开展个人独立电子商务商城最佳的选择,以下为详细功能介绍:1.最新产品-提供最新产品发布管理修改,和最新产品订单查看2.推荐产
CREATE TABLE Products ( product_name VARCHAR(50) CHECK (LENGTH(product_name) > 0) );
4. 条件表达式
CHECK 约束可以包含更复杂的条件表达式,以定义更高级的验证规则。例如:
CREATE TABLE Orders ( order_total DECIMAL(10, 2) CHECK (order_total > 0 AND order_total < 10000) );
5. 引用其他列
CHECK 约束可以引用其他列,以定义基于其他列值的数据完整性规则。例如:
CREATE TABLE Employees ( employee_id INT PRIMARY KEY, manager_id INT REFERENCES Employees(employee_id) CHECK (manager_id < employee_id) );
6. 跨表检查
当主表和子表之间存在关系时,可以在子表上使用 CHECK 约束来强制参照完整性。例如:
CREATE TABLE Orders ( order_id INT PRIMARY KEY ); CREATE TABLE OrderItems ( order_id INT REFERENCES Orders(order_id), item_id INT, quantity INT CHECK (quantity > 0) );









