本文共 1330 字,大约阅读时间需要 4 分钟。
这篇文章将深入探讨SQL Server中主键、外键、联合主键和复合主键的创建操作,使用T-SQL语句进行操作,所有相关表创建在Sales数据库中。
主键在SQL Server中通过在要设置的字段后添加PRIMARY KEY约束实现,确保表中唯一性。
以下是创建主键的示例表:
CREATE TABLE Category( CategoryID int NOT NULL PRIMARY KEY, CategoryName varchar(20) NOT NULL, Description varchar(80) NULL)
联合主键通过在表中指定多个字段组合来唯一确定记录的方式实现。
以下是创建联合主键的示例表:
CREATE TABLE grade( student char(10) NOT NULL, coursestudent char(10) NOT NULL, grade int NOT NULL, PRIMARY KEY(student, coursestudent))
复合主键是指一个表中多个字段共同组成主键的概念,每个字段都必须唯一。
以下是创建复合主键的示例表:
CREATE 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))
外键用于在多个表之间建立关联关系,确保数据的一致性。例如,主表中的主键字段在子表中作为外键引用。
可以通过在表创建时直接指定外键约束,或者在表已存在的情况下通过 ALTER TABLE命令添加外键。
以下是通过表创建时添加外键的示例:
CREATE 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)
IDENTITY函数用于生成自动递增的数值,可以设置种子值和增量值。
以下是使用IDENTITY函数设置种子和增量的示例:
CREATE 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))
转载地址:http://yawpz.baihongyu.com/