SQL 约束讲解

SQL 约束讲解
2009-04-27 09:29

约束主要包括:
  • NOT NULL
  • UNIQUE
  • PRIMARY KEY
  • FOREIGN KEY
  • CHECK
  • DEFAULT

    1、not null :用于控制字段的内容一定不能为空(NULL)。
         用法 :Create table MyTable
                   (
                       id varchar(32) not null,
                       name varchar (32)
                   )

    2、Unique :控件字段内容不能重复,一个表允许有多个 Unique 约束。
          在Sql Server、Orcale、MS Access 支持的添加 Unique 语法
                 Create table MyTable
                    (
                        id varchar(32) not null unique,
                        name varchar (32)
                    )

          在Sql Server、 My Sql 支持的添加 Unique 语法
                 Create table MyTable
                    (
                        id varchar(32) not null,
                        name varchar (32),
                       unique (id,.....)
                     )

          在Sql Server、Orcale、MS Access、My Sql 都支持的添加 Unique 语法
                  Create table MyTable
                      (
                          id varchar(32) not null,
                          name varchar (32),
                         Constraint uniqueName unique(UniqueColumn,.....)
                       )

          :第一种写法(也就是在字段后面直接添加约束),保证每个字段数据唯一性。
              第二种写法(也就是同时添加几个字段为约束),这个是保证几个字段数据同时是唯一的,比如 Unique(id,name) 两个字段为约束,那么当 id 有重复值,而 name 没有重复值的情况下是允许的,只有当两个字段数据都与原数据重复的情况下才是不允许的。
       
       在Sql Server、Oracle、MS Access 删除 Unique 约束语法:drop constraint UniqueName;
       在My Sql 删除 Unique 约束语法:drop index UniqueName;

    3、Primary Key :也是用于控件字段内容不能重复,但它在一个表只允许出现一个。
          在Sql Server、Orcale、MS Access 支持的添加Primary Key语法
                  Create table myTB1
                 (
                     id nvarchar(32) not null primary key,
                     name nvarchar(32)
                  )
          在Sql Server、My Sql 支持的添加Primary Key 语法
                 Create table myTB1
                 (
                     id nvarchar(32) not null,
                     name nvarchar(32),
                     primary key (id)
                 )
           在Sql Server、Orcale、MS Access、My Sql 支持的添加Primary Key 语法
                 Create table myTB1
                 (
                      id nvarchar(32) not null,
                     name nvarchar(32),
                     constraint PrimaryName primary key (id)
                  )
    在Sql Server、Orcale、MS Access、My Sql 表已存在的情况下,添加表的Primary Key约束语法
                  Alter table myTB1
                  ADD Primary Key (id,......) --这样的写法,系统会自定义约束名称

                  Alter table myTB1
                  Add Constaint PrimaryName primary key (id) --这样的写法,自己可以自定义约束名称

    在Sql Server、Orcale、MS Access 删除表已存在的 Primary Key 约束的语法:
                  Alter table myTB1
                  Drop Constraint PrimaryName

    在My Sql 删除表已存在的 Primary Key 约束的语法:
                  Alter table myTB1
                  Drop Primary Key
    Unique 与 Primary 的相同之处:UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
    Unique 与 Primary 的不同之处:每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束,Unique允许有NULL值,而 Primary key 不允许有NULL值。

    :在同一个数据库中,就算在不同的表中,约束名称是不允许相同的。

    4、Foreign Key :FOREIGN KEY 约束用于预防破坏表之间连接的动作,FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
       在Sql Server、My Sql 支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null primary key,
                       name nvarchar(32),
                       foreign key(id) references myTB(id)
                  )

       在Sql Server、Orcale、MS Access 支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null foreign key references myTB(id),
                       name nvarchar(32)
                  )

       在Sql Server、Orcale、MS Access、My Sql 都支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null primary key,
                       name nvarchar(32),
                        Constraint foreignName foreign key(id) references myTB(id)
                  )

    在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加外键约束的语法:
                  Alter table myTB1
                  Add foreign key(id) references myTB(id) --这样写系统会自定义约束名称

                   Alter table myTB1
                  Add Constraint foreignName foreign key(id) references myTB(id) --这样写自己可以自定义约束名称

    在Sql Server、Orcale、MS Access 中删除外键约束的语法:
                  Alter table myTB1
                  Drop Constraint foreignName;

    在My Sql 中删除外键约束的语法:
                  Alter table myTB1
                  Drop foreign key foreignName;


    5、Check :用于控制字段的值范围。
          在Sql Server、My Sql 支持的添加check 语法
                  Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null,
                      
    check (age>15 and age <30)
                  )

           在Sql Server、Orcale、MS Access 支持的添加 check 语法
                  Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null check (age>15 and age<30)
                  )

          在Sql Server、Orcale、MS Access、My Sql 都支持的添加 check 语法
                   Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null,
                       constraint checkName check (age<15 and age>30)
                  )

    在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加check约束的语法:
                  Alter table myCheck
                  add check (id='celly'); --这样定义是系统自定义 check约束名称。

                  Alter table myCheck
                   add constraint checkName check(id='celly'); --这样定义是自己自定义 check约束名称。


    在 Sql Server、Orcale、MS Access 删除表已存在的 check 约束的语法:
                  Alter table myCheck
                  drop constraint checkName

    6、Default :用于设置新记录的默认值。

          在Sql Server、Orcale、MS Access、My Sql 添加default约束的语法:
                  Create table myDefault
                  (
                      id int,
                      name nvarchar(32) default 'celly'
                  )

          在My Sql 的已存在表中添加 字段默认值:
                   Alter table myDefault
                  Alter [id] set default 0

          在 Sql Server、Orcale、MS Access 的已存在表中添加 字段默认值:
                  Alter table myDefault
                  Alter column [id] set default 0

          在 My Sql 中删除字段默认值语法:
                  Alter table myDefault
                  Alter ColumnName drop default

<think> 嗯,用户现在希望获得SQL约束的详细讲解,而且之前已经提供了三个引用内容。我需要整合这些信息,同时确保回答结构清晰。 首先看引用内容的特点: 引用[1]强调了约束的核心作用是保证数据完整性和一致性,特别是主外键的联动作用[^1]。 引用[2]列出了SQL Server的6种约束类型,这是很好的分类框架[^2]。 引用[3]则展示了具体语法,尤其是表级约束的写法示例[^3]。 用户之前提到过"约束的定义和类型",所以这次应该更侧重SQL场景下的具体实现。需要特别注意: - 区分列级约束和表级约束的语法差异 - 每种约束的适用场景要举例说明 - 主外键关系需要重点解释 注意到上次回答时用户对复合唯一键的示例很关注,这次应该在unique约束部分强化这个案例。另外管理系统里的外键级联操作是常见痛点,需要包含ON DELETE CASCADE这样的实用细节。 技术细节上要确保: - 所有SQL关键字大写保持规范 - 每个约束类型都配至少一个代码示例 - 特别说明不同数据库系统的语法差异(如MySQLSQL Server) 最后生成的三个问题要延续知识链: 1. 约束失效场景 → 引申出约束管理 2. 修改约束 → 覆盖DDL操作 3. 约束冲突 → 回到数据一致性主题 这样既能解决当前问题,又能自然引导到后续学习点。 </think> 以下是SQL约束的详细讲解,结合其在数据库中的作用、类型及实现方式: --- ### **SQL约束的核心作用** 为数据库表强制实施数据完整性规则,确保数据存储符合业务逻辑和规范[^1]。主要实现: - **实体完整性**:通过主键唯一标识记录 - **参照完整性**:通过外键维护表间关系 - **域完整性**:约束字段取值范围 --- ### **六大约束类型详解** #### 1. **非空约束 `NOT NULL`** ```sql CREATE TABLE Employees ( ID INT NOT NULL, -- 列级约束 Name VARCHAR(50) NOT NULL ); ``` - 强制字段必须有值,插入空值会报错 #### 2. **主键约束 `PRIMARY KEY`** ```sql CREATE TABLE Products ( ProductID INT PRIMARY KEY, -- 列级约束 ProductName VARCHAR(100) ); -- 或表级约束(复合主键) CREATE TABLE OrderDetails ( OrderID INT, ProductID INT, CONSTRAINT PK_OrderDetails PRIMARY KEY (OrderID, ProductID) ); ``` - 唯一标识记录,自动创建聚簇索引 - 隐含 `NOT NULL` 和 `UNIQUE` 特性 #### 3. **外键约束 `FOREIGN KEY`** ```sql CREATE TABLE Orders ( OrderID INT PRIMARY KEY, CustomerID INT, CONSTRAINT FK_CustomerOrder FOREIGN KEY (CustomerID) REFERENCES Customers(CustomerID) ON DELETE CASCADE -- 级联删除 ); ``` - 确保引用其他表的主键值有效 - 级联操作选项:`CASCADE`/`SET NULL`/`NO ACTION` #### 4. **唯一约束 `UNIQUE`** ```sql CREATE TABLE Users ( UserID INT PRIMARY KEY, Email VARCHAR(255) UNIQUE, -- 列级约束 -- 表级约束(复合唯一键) CONSTRAINT uc_NamePhone UNIQUE (UserName, Phone) ); ``` - 允许空值但禁止重复值 - 一个表可有多个唯一约束 #### 5. **检查约束 `CHECK`** ```sql CREATE TABLE Students ( ID INT PRIMARY KEY, Age INT CHECK (Age >= 18), -- 列级约束 Grade CHAR(1), -- 表级约束(多条件检查) CONSTRAINT chk_Grade CHECK (Grade IN ('A','B','C','D')) ); ``` - 验证字段值是否符合逻辑表达式 #### 6. **默认约束 `DEFAULT`** ```sql CREATE TABLE Orders ( OrderID INT PRIMARY KEY, OrderDate DATE DEFAULT GETDATE(), -- 默认当前日期 Status VARCHAR(20) DEFAULT 'Pending' ); ``` - 插入数据时自动填充未指定的值 --- ### **约束创建与修改** #### 表创建时定义 ```sql CREATE TABLE TableName ( Column1 INT CONSTRAINT PK_ID PRIMARY KEY, Column2 VARCHAR(50) NOT NULL, Column3 INT DEFAULT 0, CONSTRAINT FK_Ref FOREIGN KEY (Column3) REFERENCES OtherTable(ColumnX) ); ``` #### 表修改时添加 ```sql -- 添加主键 ALTER TABLE Employees ADD CONSTRAINT PK_EmpID PRIMARY KEY (EmployeeID); -- 添加外键 ALTER TABLE Orders ADD CONSTRAINT FK_Customer FOREIGN KEY (CustID) REFERENCES Customers(CustomerID); -- 删除约束 ALTER TABLE Products DROP CONSTRAINT chk_Price; ``` --- ### **关键注意事项** 1. **命名规范** 显式命名约束(如 `CONSTRAINT PK_ID PRIMARY KEY`)便于管理 2. **性能影响** 外键和检查约束可能降低数据写入速度 3. **跨数据库兼容性** MySQL中默认约束不可引用函数(如`DEFAULT CURRENT_TIMESTAMP`除外) 4. **约束失效场景** 批量导入数据时可临时禁用约束加速操作: ```sql ALTER TABLE Orders NOCHECK CONSTRAINT FK_Customer; -- 数据导入后重新启用 ALTER TABLE Orders CHECK CONSTRAINT FK_Customer; ``` > 通过主外键实现的参照完整性,可防止出现"订单对应不存在的客户"这类数据异常,确保数据库逻辑一致性[^1][^2]。 ---
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值