博客
关于我
数据库原理与应用(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中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>