MySQL笔记(一)之新建数据库和数据表

创建数据库

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 Persons
ALTER City SET DEFAULT 'SANDNES'
  • 撤销约束
ALTER TABLE Persons
ALTER 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 Persons
ADD UNIQUE (Id_P)

#命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束
ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
  • 撤销UNIQUE约束
ALTER TABLE table_name
DROP 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 Persons
ADD PRIMARY KEY (Id_P)

ALTER TABLE Persons
ADD CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName)
  • 撤销 PRIMARY KEY 约束
ALTER TABLE Persons
DROP 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 Orders
ADD FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)

ALTER TABLE Orders
ADD CONSTRAINT fk_PerOrders
FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)
  • 撤销 FOREIGN KEY 约束
ALTER TABLE Orders
DROP 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 Persons
ADD CHECK (Id_P>0)

ALTER TABLE Persons
ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
  • 撤销 CHECK 约束
ALTER TABLE Persons
DROP CHECK chk_Person
posted @ 2017-09-03 14:51  cnkai  阅读(567)  评论(0编辑  收藏  举报