博客
关于我
数据库原理与应用(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 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 通过查看mysql 配置参数、状态来优化你的mysql
查看>>
mysql 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>
mysql 锁机制 mvcc_Mysql性能优化-事务、锁和MVCC
查看>>
MySQL 错误
查看>>
mysql 随机数 rand使用
查看>>
MySQL 面试题汇总
查看>>
MySQL 面试,必须掌握的 8 大核心点
查看>>
MySQL 高可用性之keepalived+mysql双主
查看>>
MySQL 高性能优化规范建议
查看>>
mysql 默认事务隔离级别下锁分析
查看>>
Mysql--逻辑架构
查看>>
MySql-2019-4-21-复习
查看>>
mysql-5.6.17-win32免安装版配置
查看>>