失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 使用SQL脚本创建数据库 操作主键 外键与各种约束(MS SQL Server)

使用SQL脚本创建数据库 操作主键 外键与各种约束(MS SQL Server)

时间:2023-01-31 14:54:36

相关推荐

使用SQL脚本创建数据库 操作主键 外键与各种约束(MS SQL Server)

在实际开发中,可能很少人会手写sql脚本来操作数据库的种种。特别是微软的MS SQL Server数据库,它的SQL Server Management Studio对数据库的图形化操作极致简便,从而导致很多人都不会或不熟悉使用SQL脚本操作数据库。

接下面介绍的是我们日常开发中常规性的各种操作,先看看基本知识,随后使用coding来表述。

SQL Server 常见五种约束:

Primary Key--主键约束

Foreign Key--外键约束

Unique --唯一约束

Default --默认值约束

Check--条件约束(逻辑判断约束)

什么是主键?

在数据库中,常常不只是一个表,这些表之间也不是相互独立的。不同的表之间需要建立一种关系,才能将它们的数据相互沟通。而在这个沟通过程中,就需要表中有一个字段作为标志,不同的记录对应的字段取值不能相同,也不能是空白的。通过这个字段中不同的值可以区别各条记录。就像我们区别不同的人,每个人都有名字,但它却不能作为主键,因为人名很容易出现重复,而身份证号是每个人都不同的,所以可以根据它来区别不同的人。数据库的表中作为主键的字段就要像人的身份证号一样,必须是每个记录的值都不同,这样才能根据主键的值来确定不同的记录。

如果为表指定了 PRIMARY KEY 约束,则 SQL Server 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。

创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 PRIMARY KEY 约束。

唯一性约束

1) 唯一性约束所在的列允许空值,但是主键约束所在的列不允许空值。

(2) 可以把唯一性约束放在一个或者多个列上,这些列或列的组合必须有唯一的只。但是,唯一性约束所在的列并不是表的主键列。

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

主键:

1) 用于标识某行而且与之相关.

2) 是不可能(或很难)更新.

3) 不应该允许空(NULL).

唯一域/字段:

1) 用于作为访问某行的可选手段.

2) 只要唯一就可以更新.

3) 可以为空(NULLs).

注意唯一和主键的区别,它们都是创建一个唯一的索引,一个表格仅含有一个主键约束列,但是,它有可能在其他列中含有许多的唯一约束。

1、Primary Key约束

在表中常有一列或多列的组合,其值能唯一标识表中的每一行。

这样的一列或多列成为表的主键(PrimaryKey)。一个表只能有一个主键,而且主键约束中的列不能为空值。只有主键列才能被作为其他表的外键所创建。

2、Foreign Key约束

外键约束是用来加强两个表(主表和从表)的一列或多列数据之间的连接的。创建外键约束的顺序是先定义主表的主键,然后定义从表的外键。也就是说只有主表的主键才能被从表用来作为外键使用,被约束的从表中的列可以不是主键,主表限制了从表更新和插入的操作。

3、Unique约束

唯一约束确保表中的一列数据没有相同的值。与主键约束类似,唯一约束也强制唯一性,但唯一约束用于非主键的一列或者多列的组合,且一个表可以定义多个唯一约束。

4、Default约束

若在表中定义了默认值约束,用户在插入新的数据行时,如果该行没有指定数据,那么系统将默认值赋给该列,如果我们不设置默认值,系统默认为NULL。

5、Check约束

Check约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围。在列中更新数据时,所要输入的内容必须满足Check约束的条件,否则将无法正确输入。

---创建数据库,语句: create database 表名

Create database School

----删除数据库,语句:drop database 表名

drop database School

--创建数据表,语句:create table 表名( 字段A 类型 可空, 字段B 类型 可空)

Create Table Grade(Id int not null identity(1,1), --identity 设置字段自增长,步进值为1Name nvarchar not null)

--创建主键约束,语句: alter table 表名 add constraint [主键名称] primary key (主键字段)

alter table Grade Add constraint [PK_Grade] primary key (Id)

--创建唯一约束,语句: alter table 表名 add constraint [约束名称] unique (字段 排序)

alter table Grade add constraint [IX_Grade_Name] unique (Id asc)

--创建数据表,语句:create table 表名( 字段A 类型 可空, 字段B 类型 可空)

create Table Student(Id int not null identity,Cid int not null,Name nvarchar(100) not null,Gender nchar(8) not null)

--创建主键约束,语句: alter table 表名 add constraint [主键名称] primary key (主键字段)

alter table Student Add constraint PK_Student primary key (Id)

--创建外键约束,语句: alter table 表名 add constraint [外键名称] foreign key (字段) references 外链表名(字段)

alter table Student Add constraint FK_Student_Cid foreign key (Id) references Grade(Id)

--创建唯一约束,语句:alter table 表名 add constraint [约束名称] unique (字段 排序)

alter table Student Add constraint IX_Student_Name unique (Id desc)

--创建Default约束,语句:alter table 表名 add constraint [约束名称] default (默认值) for (字段)

alter table Student add constraint DF_Student_Gender default (N'男') FOR [Gender]

--创建Check约束,语句:alter table 表名 add constraint [约束名称] check (逻辑表达式)

alter table Student add constraint CK_Student_Gender CHECK (([Gender]=N'男' OR [Gender]=N'女'))

--删除约束,语句: alter table 表名 drop constraint [约束名称]

alter table Student drop constraint IX_Student_Name

--修改字段,语句:alter table 表名 alter column [字段名] 类型 可空

alter table Grade alter column [Name] nvarchar(100) not null

--添加字段,语句:alter table 表名 add [字段名] 类型 可空

alter table Grade add [Year] char(8) not null

--删除字段,语句:alter table drop column [字段名]

alter table Grade drop column [Year]

--填充数据

insert into Grade select N'一年级','' --方法一insert into Grade(Name,[Year]) values (N'二年级','') --方法二insert into Grade select N'三年级',''insert into Student select 2,N'张三','男'insert into Student select 2,N'李四','男'insert into Student select 3,N'王五','男'insert into Student select 3,N'赵六','男'insert into Student select 3,N'马七','女'

--假设由于业务变更,我们需要给Student表新增非空IdNumber字段--

明天继续....

如果觉得《使用SQL脚本创建数据库 操作主键 外键与各种约束(MS SQL Server)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。