A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

云水

初级黑马

  • 黑马币:17

  • 帖子:8

  • 精华:0

© 云水 初级黑马   /  2016-12-11 22:45  /  929 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

                        SQL 约束
约束用于限制加入表的数据的类型。
可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后也可以(通过 ALTER TABLE语句)。
(1)NOT NULL约束强制列不接受NULL 值。如果不向字段添加值,就无法插入新记录或者更新记录。
(2)UNIQUE 约束唯一标识数据库表中的每条记录。
  CREATE TABLE Persons
  (Id_P int NOT NULL,
    LastNamevarchar(255) NOT NULL,
    UNIQUE (Id_P))创建unique
    CONSTRAINTuc_PersonID UNIQUE (Id_P,LastName)命名unique约束
当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束
  ALTER TABLE Persons
  ADD CONSTRAINT uc_PersonID UNIQUE(Id_P,LastName)创建unique
  ADD CONSTRAINT uc_PersonID UNIQUE(Id_P,LastName)命名unique并定义多列的约束
  DROP INDEX uc_PersonID撤销unique约束
(4)PRIMARY KEY 拥有自动定义的 UNIQUE 约束。
  每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY约束。
   PRIMARY KEY约束唯一标识数据库表中的每条记录。
   主键必须包含唯一的值。
   主键列不能包含 NULL 值。
  每个表都应该有一个主键,并且每个表只能有一个主键。
   CREATE TABLE Persons
   (Id_P int NOT NULL,
   LastName varchar(255) NOTNULL,
   City varchar(255),
   PRIMARY KEY (Id_P)创建主键约束
    CONSTRAINTuc_PersonID PRIMARY KEY (Id_P,LastName)命名主键约束
  ALTER TABLE Persons
  ADD PRIMARY KEY (Id_P)如果在表已存在的情况下为 "Id_P" 列创建PRIMARY KEY 约束
  ADD CONSTRAINT pk_PersonID PRIMARY KEY(Id_P,LastName)命名约束,并且为多列定义  约束 DROP PRIMARY KEY撤销约束)一旦确定为主键,则该字段不可为空也不可以重复。
(5)FOREIGN KEY 一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。
    CREATE TABLE Orders
    (O_Id intNOT NULL,
    Id_Pint,
    FOREIGN KEY(Id_P) REFERENCES Persons(Id_P))在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGNKEY:
  CONSTRAINT fk_PerOrders FOREIGN KEY(Id_P)REFERENCES Persons(Id_P)命名、多列
如果在 "Orders" 表已存在的情况下为 "Id_P" 列创建 FOREIGN KEY 约束
  ALTER TABLE Orders
ADD FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)  创建
ALTER TABLE Orders
DROP FOREIGN KEY fk_PerOrders  撤销
(6)CHECK  约束用于限制列中的值的范围。
    如果对单个列定义CHECK 约束,那么该列只允许特定的值。
    如果对一个表定义CHECK 约束,那么此约束会在特定的列中对值进行限制。
    CHECK(Id_P>0)创建check约束
    CONSTRAINTchk_Person CHECK (Id_P>0 AND City='Sandnes')重命名约束
  在表已经存在的情况下,添加约束ALTER TABLE Persons ADD CHECK(Id_P>0)
  重命名约束ALTER TABLE Persons ADD CONSTRAINTchk_Person CHECK (Id_P>0 AND  City='Sandnes')
  撤销约束ALTER TABLE Persons DROP CHECKchk_Person
(7)DEFAULT DEFAULT 约束用于向列中插入默认值。
如果没有规定其他的值,那么会将默认值添加到所有的新记录。
   City varchar(255) DEFAULT'Sandnes'创建约束
   如果在表已存在的情况下为 "City" 列创建DEFAULT 约束
   ALTER TABLE Persons
   ALTER City SET DEFAULT'SANDNES'创建
   ALTER TABLE Persons
   ALTER City DROP DEFAULT 撤销
                                                                       

2 个回复

倒序浏览
回复 使用道具 举报
wujianming 来自手机 注册黑马 2016-12-12 00:33:09
藤椅
楼主厉害。。。。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马