创建数据库
CREATE DATABASE database_name
创建数据表
CREATE TABLE table_name(列1 数据类型,列2 数据类型,列3 数据类型,....)#常见的数据类型 integer(size) 整型 int(size) 整型 numeric(size,d) 浮点型 char(size) 固定长度字符型 varchar(size) 可变长度字符型 date(yyyymmdd) 日期类型
数据表的约束
NOT NULL
强制列不接受 NULL 值
CREATE TABLE Persons(Id_P int NOT NULL,City varchar(255))
DEFAULT
用于向列中插入默认值。
- 创建时添加约束
CREATE TABLE Persons(Id_P int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255) DEFAULT 'Sandnes'OrderDate date DEFAULT GETDATE() # 可以使用函数)
- 创建后添加约束
ALTER TABLE PersonsALTER City SET DEFAULT 'SANDNES'
- 撤销约束
ALTER TABLE PersonsALTER City DROP DEFAULT
UNIQUE
唯一标识数据库表中的每条记录,一个数据表中可以有多个UNIQUE约束。
- 创建时添加UNIQUE约束
CREATE TABLE table_name(Id_P int NOT NULL,City varchar(255),UNIQUE (Id_P) # 为一列指定UNIQUE约束CONSTRAINT uc_PersonID UNIQUE (Id_P,City) # 命名UNIQUE 约束,并且为多列指定UNIQUE约束)
- 创建后添加约束
#添加一个约束ALTER TABLE PersonsADD UNIQUE (Id_P)#命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束ALTER TABLE PersonsADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
- 撤销UNIQUE约束
ALTER TABLE table_nameDROP INDEX uc_PersonID
PRIMARY KEY
主键必须包含唯一的值,主键列不能包含 NULL 值。
每个表都应该有一个主键,并且每个表只能有一个主键。- 创建时添加PRIMARY KEY约束
CREATE TABLE Persons(Id_P int NOT NULL,City varchar(255),PRIMARY KEY (Id_P) # 为一列指定UNIQUE约束CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,City) #命名 PRIMARY KEY 约束,以及为多个列定义 PRIMARY KEY 约束)
- 创建后添加PRIMARY KEY 约束
ALTER TABLE PersonsADD PRIMARY KEY (Id_P)ALTER TABLE PersonsADD CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName)
- 撤销 PRIMARY KEY 约束
ALTER TABLE PersonsDROP PRIMARY KEY
FOREIGN KEY
指向另一个表中的 PRIMARY KEY
- 创建时添加FOREIGN KEY约束
CREATE TABLE Orders(Id_O int NOT NULL,OrderNo int NOT NULL,Id_P int,PRIMARY KEY (Id_O),FOREIGN KEY (Id_P) REFERENCES Persons(Id_P) # 一个约束CONSTRAINT fk_PerOrders FOREIGN KEY (Id_P) REFERENCES Persons(Id_P) # 命名约束且指定多个约束)
- 创建后添加PFOREIGN KEY 约束
ALTER TABLE OrdersADD FOREIGN KEY (Id_P)REFERENCES Persons(Id_P)ALTER TABLE OrdersADD CONSTRAINT fk_PerOrdersFOREIGN KEY (Id_P)REFERENCES Persons(Id_P)
- 撤销 FOREIGN KEY 约束
ALTER TABLE OrdersDROP FOREIGN KEY fk_PerOrders
CHECK
束用于限制列中的值的范围
- 创建时添加CHECK约束
CREATE TABLE Persons(Id_P int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),CHECK (Id_P>0)CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes'))
- 创建后添加CHECK约束
ALTER TABLE PersonsADD CHECK (Id_P>0)ALTER TABLE PersonsADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
- 撤销 CHECK 约束
ALTER TABLE PersonsDROP CHECK chk_Person