失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 数据库原理与应用(SQL Server)教程 主键 外键以及联合主键 复合主键和设置种子

数据库原理与应用(SQL Server)教程 主键 外键以及联合主键 复合主键和设置种子

时间:2020-03-05 16:24:07

相关推荐

数据库原理与应用(SQL Server)教程 主键 外键以及联合主键 复合主键和设置种子

文章目录

前言一、主键、联合主键和复合主键(一)主键(二)联合主键(三)复合主键二、外键、设置种子数目和增量(一)外键的概念(二)添加外键(三)设置种子数目和增量结语

前言

这篇文章,我们将通过知识点以及例子来了解SQL Server中主键、外键以及联合主键和复合主键的相关创建操作,以下我们均使用T-SQL语句来创建。

注:以下例子中所有的数据表都创建在Sales数据库下。

一、主键、联合主键和复合主键

(一)主键

主键格式:

主键即在要设置的字段的后面加上PRIMARY KEY就可以了。

我们给出下表,也就是我们接下来要用T-SQL语句进行操作的表:

在SQL Server查询分析器中输入以下语句:

USE SalesCREATE TABLE Category(CategoryID int NOT NULL PRIMARY KEY,CategoryName varchar(20) NOT NULL,Description varchar(80) NULL)

(二)联合主键

联合主键就是用多个字段一起组成主键,例如:

USE SalesCREATE TABLE grade(student char(10) NOT NULL,coursestudent char(10) NOT NULL,grade int NOT NULL,PRIMARY KEY(student,coursestudent))

其中字段student和coursestudent就是联合主键

(三)复合主键

复合主键跟联合主键的差别是联合主键体现在多个表上,而复合主键体现在一个表中的多个字段。复合主键即数据表中的主键含有一个以上的字段组成。

例如:

USE SalesCREATE TABLE Test(NO_1 char(10) NULL, NO_2 char(20) NOT NULL,NO_3 varchar(10) NOT NULL,PRIMARY KEY(NO_1,NO_2))

这上面的PRIMARY KEY(NO_1,NO_2)组合起来就是复合主键

二、外键、设置种子数目和增量

(一)外键的概念

外键即用于与另外一个数据表的关联,是确定另一个表的字段,例如有两个表分别是基本表A和信息表B,其中C是表A的主键,而表B中也有C字段,则我们称C就是B的外键,所以外键的作用就是来维护多个表之间数据的一致性。

(二)添加外键

添加外键我们分为两种,一种是在创建数据表时设置外键,另一种则是修改表的形式来设置,我们先来看第一种的格式:

CREATE TABLE Test(列名 <参数>,[,...n]FOREIGN KEY <列名> REFERENCES <目标表名>)

第二种格式,也就是我们已经创建了表,现在通过修改表来添加外键:

ALTER TABLE TestADD CONSTRAINT <外键名> REFERENCES <外键表(即被别的表引为外键的表)>

(三)设置种子数目和增量

设置种子数目和增量的格式是:

列名IDENTITY(种子数目,种子增量)

e.g.

USE SalesCREATE TABLE Test(NO_1 char(10) IDENTITY(1000,1) NULL, NO_2 char(20) NOT NULL,NO_3 varchar(10) NOT NULL,PRIMARY KEY(NO_1,NO_2))

上sql语句中,“NO_1 char(10) IDENTITY(1000,1) NULL”, IDENTITY(1000,1)表示的含义就是其约束是自动增长种子1000,增长值为1。

接下来我们通过一个例子来深刻了解外键以及设置种子数目和增量的用法来创建数据表。

例:给出下表,使用T-SQL语句进行建表

在SQL Server查询分析器中输入以下语句:

USE SalesCREATE TABLE Orders(OrderID int IDENTITY(1001,1) NOT NULL PRIMARY KEY,CustomerID char(3) NOT NULL ,SaleID char(3) NOT NULL,OrderDate datetime NULL,Notes varchar(80) NULL,FOREIGN KEY CustomerID REFERENCES Orders,FOREIGN KEY SaleID REFERENCES Orders)

结语

文章到此结束,如有错误欢迎读者指出!

数据库原理与应用(SQL Server)教程 主键 外键以及联合主键 复合主键和设置种子数目和增量

如果觉得《数据库原理与应用(SQL Server)教程 主键 外键以及联合主键 复合主键和设置种子》对你有帮助,请点赞、收藏,并留下你的观点哦!

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