约束是SQL Server提供的自动保持数据库完整性的一种方法, 它通过限制字段中数据、记录中数据和表之间的数据来保证数据的完整性。

约束可分为以下几种:

1、PRIMARY KEY       主键约束
2、FOREIGN KEY       外键约束
3、UNIQUE    约束      唯一约束
4、CHECK 约束      检查约束
5、DEFUALT 定义        默认约束

一、主键约束

如果对多列定义了 PRIMARY KEY 约束,则一列中的值可能会重复,但来自 PRIMARY KEY 约束定义中所有列的任何值组合必须唯一。

如图:

sql server 怎么删除唯一约束 sql数据库删除唯一约束_sql server 怎么删除唯一约束

主键约束的定义:

     1. 列中不允许有空值
     2. 列中不允许有重复的值,即主键列中每个值都是唯一的。
     3. 如果另一个表中的 FOREIGN KEY 约束引用了 PRIMARY KEY 约束,则必须先删除 FOREIGN KEY 约束。
     4. 表包含应用于自身的 PRIMARY XML 索引

主键的创建:

    1、 在创建表时创建 PRIMARY KEY 约束

 以下是AdventureWorks2008R2 示例数据库中 Employee 表(允许系统提供约束名)的 BusinessEntityID 列具有聚集索引的 PRIMARY KEY 约束的列定义
BusinessEntityID int
PRIMARY KEY CLUSTERED
2、为现有表创建或删除 PRIMARY KEY 约束
USE AdventureWorks2008R2;
GO
ALTER TABLE Production.TransactionHistoryArchive WITH NOCHECK 
ADD CONSTRAINT PK_TransactionHistoryArchive_TransactionID PRIMARY KEY CLUSTERED (TransactionID)
WITH (FILLFACTOR = 75, ONLINE = ON, PAD_INDEX = ON);
GO
3、删除主键约束

使用表设计器,在表网格中右键单击包含主键的行,再选择“移除主键”以将该设置从启用切换到禁用。

或者新建查询文件,键入
    USE AdventureWorks2008R2;
    GO
    --修改表Production
    ALTER TABLE Production.TransactionHistoryArchive            
    DROP CONSTRAINT PK_TransactionHistoryArchive_TransactionID
    GO

“`

二、FOREIGN KEY 外键约束

外键 (FK) 是用于建立和加强两个表数据之间的链接的一列或多列。当创建或修改表时可通过定义 FOREIGN KEY 约束来创建外键。

例如,因为销售订单和销售人员之间存在一种逻辑关系,所以 AdventureWorks2008R2 数据库中的 Sales.SalesOrderHeader 表含有一个指向 Sales.SalesPerson 表的链接。SalesOrderHeader 表中的 SalesPersonID 列与 SalesPerson 表中的主键列相对应。SalesOrderHeader 表中的 SalesPersonID 列是指向 SalesPerson 表的外键。

sql server 怎么删除唯一约束 sql数据库删除唯一约束_sql server_02

外键约束要遵循引用完整性原则

建立外键约束的基本格式为:
    FOREIGN KEY(列名) REFERENCES 被参照表名(列名)
例:
1、创建表时添加外键约束
    SalesPersonID int NULL
    REFERENCES SalesPerson(BusinessEntityID)

 2、修添改表时加约束,显示指定外键约束两个表中列名不必相同
    FOREIGN KEY (SalesPersonID) REFERENCES SalesPerson(BusinessEntityID)

3、删除外键
ALTER TABLE Person.ContactBackup
DROP CONSTRAINT FK_ContactBacup_Contact

三、UNIQUE 约束 唯一约束

唯一约束可确保在非主键列中不输入重复的值,可以对一个表定义多个唯一约束

1、在建表时创建唯一约束:

Name nvarchar(100) NOT NULL 
UNIQUE NONCLUSTERED 

2、在现有表中创建 UNIQUE 约束 

新建查询,键入
USE DATABASE1                 --使用DATABASE1数据库
ALTER TABLE T1                --修改表T1
CONSTRAINT UQ_ID UNIQUE(ID) --为名为ID列的唯一约束

3、删除唯一约束
```
CREATE TABLE dbo.doc_exc ( column_a INT
CONSTRAINT my_constraint UNIQUE) ;  --指定表和唯一约束的列
GO
ALTER TABLE dbo.doc_exc DROP CONSTRAINT my_constraint ;
GO
```

4、CHECK 约束 检查约束

检查约束常用来检查某列的元素值是否在合理的范围之内,CHECK 约束可以强制域的完整性.

1、在创建表时创建检查约束

CreditRating int NOT NULL
CHECK (CreditRating >= 1 and CreditRating <= 5),  --将CreditRating 的值约束在1到5之间

 2、在修改表时创建约束
CREATE TABLE dbo.doc_exd
--将使用 WITH NOCHECK 以避免根据现有行验证该约束
ALTER TABLE dbo.doc_exd WITH NOCHECK 
ADD CONSTRAINT exd_check CHECK (CreditRating >= 1 and CreditRating <= 5),

注:不能在 text、ntext 或 image 列上定义 CHECK 约束

3、删除CHECK约束
ALTER TABLE doc_exd.CreditRating 
DROP CONSTRAINT CK_CreditRating  ;

5、DEFUALT 定义 默认约束

默认约束强制数据完整性,记录中的每列均必须有值,即使该值是 NULL。
使用默认约束可在表中的列元素缺省的情况下(未填入)为列中的每个元素设置默认值。

DEFAULT 定义和列的为空性所定义的列中的值可归纳如下表中所示:

sql server 怎么删除唯一约束 sql数据库删除唯一约束_sql server_03

1、在建表时添加默认约束
Position nvarchar(20) NULL
--为职位赋一个默认的字符串
DEFAULT 'New Position - title not formalized yet',

 2、在现有表中添加默认约束
 ALTER TABLE dbo.T1
 ADD CONSTRAINT Position 
 DEFAULT 'New Position - title not formalized yet' FOR Position ;

3、删除默认值

语法DROP DEFAULT { [ schema_name . ] default_name } [ ,...n ] [ ; ]

USE AdventureWorks2008R2;
GO
IF EXISTS (SELECT name FROM sys.objects
         WHERE name = 'datedflt' 
            AND type = 'D')
   DROP DEFAULT datedflt
GO