学习SQL的第七天(11月6日)
gogogo...
SQL FOREIGN KEY Constraint on CREATE TABLE
在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGN KEY
MySQL:
CREAT TABLE Orders
(
Id_o int NOT NULL,
OrderNO int NOT NULL,
Id_p int
PRIMARY KEY (Id_o)
FOREGIN KEY (Id_p) REFERENCES Persons (Id_p)
)
references是在为表创建外键时的一个固定语法里的词
SQL Server / Oracle / MS Access:
CREAT TABLE Orders
(
Id_o int NOT NULL PRIMARY KEY,
OrderNO int NOT NULL,
Id_p int FOREGIN KEY REFERENCES Persons(Id_p)
)
需要命名 FOREIGN KEY 约束,以及为多个列定义 FOREIGN KEY 约束时
CREAT TABLE Persons
(
Id_o int NOT NULL,
OrderNo int NOT NULL,
Id_p int,
PRIMART KEY (Id_o) ,
CONSTRAINT fk_PerOrders FOREIGN KEY (Id_p) REFERENCES Persons (Id_p)
)
SQL FOREIGN KEY Constraint on ALTER TABLE
如果在 "Orders" 表已存在的情况下为 "Id_P" 列创建 FOREIGN KEY 约束
ALTER TABLE Oders
ADD FOREIGN KEY (Id_p)
REFERENCES Persons(Id_p)
需要命名 FOREIGN KEY 约束,以及为多个列定义 FOREIGN KEY 约束时:
MySQL / SQL Server / Oracle / MS Access
ALTER TABLE Orders
ADD CONSTRAINT fk_PerOrders
FOREIGN KEY (Id_p)
REFERENCES Person(Id_p)
* foreign(外键字段) references 主表(主表主键字段)
撤销 FOREIGN KEY 约束
MySQL
ALTER TABLE Orders
DROP FOREIGN KEY fk_PerOrders
SQL Server / Oracle / MS Access
ALTER TABLE Orders
DROP CONSTRAINT fk_PerOrders
SQL CHECK 约束
CHECK 约束用于限制列中的值的范围。
如果对单个列定义 CHECK 约束,那么该列只允许特定的值。
如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制
My SQL
CREAT TABLE Persons
(
Id_p int NOT NULL,
Lastname varchar(255) NOT NULL,
Firstname varchar(255),
Address varchar(255),
CHECK (Id_p >0)
)
SQL Server / Oracle / MS Access
CREAT TABLE Persons
(
Id_p int NOT NULL CHECK (Id_p >0),
Lastname varchar(255) NOT NULL,
Firstname varchar(255),
Address varchar(255)
)
需要命名 CHECK 约束,以及为多个列定义 CHECK 约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT chk_Person CHECK (Id_p>0 AND City='BeiJing')
)
SQL CHECK Constraint on ALTER TABLE
如果在表已存在的情况下为 "Id_P" 列创建 CHECK 约束,用下面的语法:
MySQL / SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ADD CHECK (Id_p>0)
如果需要命名 CHECK 约束,以及为多个列定义 CHECK 约束,用下面的语法:
MySQL / SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ADD CONSTRAINT chk_Person CHECK (Id_p>0 AND City='BeiJing')
)
SQL DEFAULT 约束
DEFAULT 约束用于向列中插入默认值。
如果没有规定其他的值,那么会将默认值添加到所有的新记录。
SQL DEFAULT Constraint on CREATE TABLE
在 "Persons" 表创建时为 "City" 列创建 DEFAULT 约束
My SQL / SQL Server / Oracle / MS Access:
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255) DEFAULT 'BeiJing'
)
通过使用类似 GETDATE() —— ( 按 datetime 值的 Microsoft® SQL Server™ 标准内部格式返回当前系统日期和时间 )这样的函数,DEFAULT 约束也可以用于插入系统值:
CREATE TABLE Orders
(
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
OrderDate date DEFAULT GETDATE()
)
SQL DEFAULT Constraint on ALTER TABLE
在表已存在的情况下为 "City" 列创建 DEFAULT 约束:
MySQL:
ALTER TABLE Persons
ALTER City SET DEFAULT 'BeiJing'
SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ALTER Colunm City SET DEFAULT 'BeiJing'
撤销 DEFAULT 约束
MySQL:
ALTER TABLE Persons
ALTER City DROP DEFAULT
SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ALTER Column City DROP DEFAULT
这两天被同桌安利了中岛美嘉,看了她的两首歌MV,感动的一塌糊涂 ....
晚安 (′-ω-`)