学习SQL的第七天(11月6日)

2017-11-06  本文已影响14人  旅兔seven

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,感动的一塌糊涂 ....

晚安 (′-ω-`) 

上一篇下一篇

猜你喜欢

热点阅读