gogogo...
SQL FOREIGN KEY Constraint on CREATE TABLE
在 "Orders" 表創(chuàng)建時(shí)為 "Id_P" 列創(chuàng)建 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是在為表創(chuàng)建外鍵時(shí)的一個(gè)固定語(yǔ)法里的詞
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 約束,以及為多個(gè)列定義 FOREIGN KEY 約束時(shí)
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" 列創(chuàng)建 FOREIGN KEY 約束
ALTER TABLE Oders
ADD FOREIGN KEY (Id_p)
REFERENCES Persons(Id_p)
需要命名 FOREIGN KEY 約束攀操,以及為多個(gè)列定義 FOREIGN KEY 約束時(shí):
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 約束用于限制列中的值的范圍发钝。
如果對(duì)單個(gè)列定義 CHECK 約束,那么該列只允許特定的值博烂。
如果對(duì)一個(gè)表定義 CHECK 約束木西,那么此約束會(huì)在特定的列中對(duì)值進(jìn)行限制
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 約束义桂,以及為多個(gè)列定義 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" 列創(chuàng)建 CHECK 約束找筝,用下面的語(yǔ)法:
MySQL / SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ADD CHECK (Id_p>0)
如果需要命名 CHECK 約束,以及為多個(gè)列定義 CHECK 約束慷吊,用下面的語(yǔ)法:
MySQL / SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ADD CONSTRAINT chk_Person CHECK (Id_p>0 AND City='BeiJing')
)
SQL DEFAULT 約束
DEFAULT 約束用于向列中插入默認(rèn)值袖裕。
如果沒有規(guī)定其他的值,那么會(huì)將默認(rèn)值添加到所有的新記錄溉瓶。
SQL DEFAULT Constraint on CREATE TABLE
在 "Persons" 表創(chuàng)建時(shí)為 "City" 列創(chuàng)建 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? 標(biāo)準(zhǔn)內(nèi)部格式返回當(dāng)前系統(tǒng)日期和時(shí)間 )這樣的函數(shù)急鳄,DEFAULT 約束也可以用于插入系統(tǒng)值:
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" 列創(chuàng)建 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,感動(dòng)的一塌糊涂 ....
晚安 (′-ω-`)?