博客
关于我
数据库原理与应用(SQL Server)教程 主键、外键以及联合主键、复合主键和设置种子数目和增量
阅读量:571 次
发布时间:2019-03-09

本文共 1872 字,大约阅读时间需要 6 分钟。

文章目录


前言

这篇文章,我们将通过知识点以及例子来了解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 KET
<列名>
REFERENCES
<目标表名>
)

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

ALTER TABLE Test  ADD 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)

结语

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

转载地址:http://yawpz.baihongyu.com/

你可能感兴趣的文章
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql skip-grant-tables_MySQL root用户忘记密码怎么办?修改密码方法:skip-grant-tables
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql sysbench测试安装及命令
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>