SQLServer之UNIQUE约束

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: 原文:SQLServer之UNIQUE约束UNIQUE约束添加规则 1、唯一约束确保表中的一列数据没有相同的值。 2、与主键约束类似,唯一约束也强制唯一性,但唯一约束用于非主键的一列或者多列的组合,且一个表可以定义多个唯一约束。
原文: SQLServer之UNIQUE约束

UNIQUE约束添加规则

1、唯一约束确保表中的一列数据没有相同的值。

2、与主键约束类似,唯一约束也强制唯一性,但唯一约束用于非主键的一列或者多列的组合,且一个表可以定义多个唯一约束。

使用SSMS数据库管理工具添加UNIQUE约束

1、连接数据库,选择数据库,选择数据表-》右键点击-》选择设计。

2、在表设计窗口中-》选择要添加约束的数据列-》右键点击-》选择索引/键。

3、在索引/键窗口中-》点击添加。

4、选择新增的索引/键-》在常规窗口中-》类型选择唯一键。

5、在常规窗口中-》点击列。

 

6、在索引列窗口中-》先选择约束列-》然后选择约束列排序规则-》点击确定。

7、在索引/键弹出框中常规窗口中-》在名称中输入约束名称-》在说明中输入约束描述-》其他可以选择默认-》点击关闭。

8、点击保存按钮(或者ctrl+s)-》刷新表,查看结果。

 使用T-SQL脚本添加UNIQUE约束

当表结构已存在时

给一列或者多列添加唯一约束时,先判断要添加的约束是否存在,如果存在则先删除再添加,如果不存在则直接添加。

语法:

if exists(select * from sysobjects where name=约束名)
alter table 数据库名.[dbo].表名 drop constraint 约束名;
go
alter table 数据库名.[dbo].表名 add constraint 约束名 unique(列名1,列名2);
go

示例:

if exists(select * from sysobjects where name='unique_t_name')
alter table [testss].[dbo].[test1] drop constraint unique_t_name;
go
alter table [testss].[dbo].[test1] add constraint unique_t_name unique(name,sex);
go

当表结构不存在时

当表结构不存在时,需要在建表语句中添加,添加一列唯一索引和多列唯一索引语法相同。

语法:

--当表结构不存在时添加唯一约束
if exists( select * from sysobjects where name=数据库名.[dbo].表名 and type ='U')
drop table 数据库名.[dbo].表名;
go

--当表结构不存在时
--建表语法声明
create table 数据库名.[dbo].表名
(
--字段声明
列名1 int identity(1,1) not null,
列名2 nvarchar(50) null,
列名3 int not null,
primary key clustered(列名1 asc) with(ignore_dup_key=off) on [primary], --主键索引声明
constraint unique_name_sex unique(列名2,列名3)
)on [primary]

--字段注释声明
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'描述1' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名1';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'描述2' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名2';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'描述3' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名3';
go

示例:

--当表结构不存在时添加唯一约束
if exists( select * from sysobjects where name='test1'and type ='U')
drop table test1;
go

--当表结构不存在时
--建表语法声明
create table test1
(
--字段声明
id int identity(1,1) not null,
name nvarchar(50) null,
age int not null,
primary key clustered(id asc) with(ignore_dup_key=off) on [primary], --主键索引声明
constraint unique_name_sex unique(name,age)
)on [primary]

--字段注释声明
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'id主键' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'id';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'name';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'年龄' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'age';
go

UNIQUE索引优缺点

优点:

1、唯一性约束所在的列允许空值。

2、可以把唯一性约束放在一个或者多个列上,这些列或列的组合必须有唯一的。

 3、唯一性约束强制在指定的列上创建一个唯一性索引。在默认情况下,创建唯一性的非聚簇索引,但是,也可以指定所创建的索引是聚簇索引。

缺点:

1、创建唯一约束时会创建索引,占用磁盘空间。

2、插入或者修改约束列的值时,会存在校验规则,会比较费事。

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
29天前
|
SQL 数据库
sqlserver建库建表建约束,删库删表删约束的示例总结
sqlserver建库建表建约束,删库删表删约束的示例总结
12 0
|
1月前
|
数据库
SQLSERVER 2014 删除数据库定时备份任务提示失败DELETE 语句与 REFERENCE 约束“FK_subplan_job_id“冲突
SQLSERVER 2014 删除数据库定时备份任务提示失败DELETE 语句与 REFERENCE 约束“FK_subplan_job_id“冲突
|
9月前
|
SQL 存储 数据库
SQL Server——规则是什么?规则和约束有什么不同?
是单独的SQL Server对象,可以关联到一个或几个表中的一列或几列。它可以使用多种方式来完成对数据值的检验,可以使用函数返回验证信息,也可以使用关键字BETWEEN、LIKE和IN完成对输入数据的检查
|
存储 SQL Go
|
SQL 数据安全/隐私保护 Python
SQL Server常见的约束条件
SQL Server常见的约束条件
|
SQL 数据库
sqlserver建库建表建约束,删库删表删约束的示例总结
sqlserver建库建表建约束,删库删表删约束的示例总结
89 0
|
SQL 存储 Oracle
sql server系列_01表和约束
sql server系列_01表和约束
sql server系列_01表和约束
SQLServer:GUI方式、SQL语句两种方式建立视图和GUI方式设置主键、约束等
SQLServer:GUI方式、SQL语句两种方式建立视图和GUI方式设置主键、约束等
SQLServer:GUI方式、SQL语句两种方式建立视图和GUI方式设置主键、约束等
|
SQL Go 数据库
SQL Server使用sp_rename重命名约束注意事项
SQL Server使用sp_rename重命名约束注意事项在SQL Server中,我们可以使用sp_name这个系统存储过程重命名数据库中对象的名称。 此对象可以是表、 索引、 列、 别名,约束等数据类型(具体可以参考官方文档)。
1281 0
|
数据库 SQL 存储
SQLServer约束介绍
原文:SQLServer约束介绍 约束定义 对于数据库来说,基本表的完整性约束分为列级约束条件和表级约束条件: 列级约束条件        列级约束条件是对某一个特定列的约束,包含在列定义中,可以直接跟在该列的其他定义之后,用空格分隔,不用指定列名。
919 0