美文网首页
学习SQL的第七天(11月6日)

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

作者: 旅兔seven | 来源:发表于2017-11-06 22:26 被阅读14次

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

    晚安 (′-ω-`) 

    相关文章

      网友评论

          本文标题:学习SQL的第七天(11月6日)

          本文链接:https://www.haomeiwen.com/subject/gbllmxtx.html