CONSTRAINT(编程命令)

生活百科 2023-01-25 19:31生活百科www.aizhengw.cn

CONSTRAINT(编程命令)

CONSTRAINT 子句是指 限制和索引相似,虽然限制也能被用于建立和另一个表的关联。 用 ALTER TABLE 和 CREATE TABLE 语句中的 CONSTRAINT 子句来建立或删除条件.CONSTRAINT 子句可分为两种类型第一种是在单一栏位上创建条件;第二种是在一个以上的栏位上创建条件。

基本介绍

  • 外文名CONSTRAINT
  • 子句指 限制和索引相似
  • 类别编程命令
  • 範畴计算机语言

语法

单一栏位条件

CONSTRAINT名 {PRIMARY KEY | UNIQUE | NOT NULL |
REFERENCES 外部表 [(外部栏位1,外部栏位2)]
[ON UPDATE CASCADE | SET NULL]
[ON DELETE CASCADE | SET NULL]}

多重栏位条件

CONSTRAINT名
CONSTRAINT name
{PRIMARY KEY (primary1[, primary2 [, ...]])|
|
UNIQUE (unique1[, unique2 [, ...]])|
|
NOT NULL (notnull1[, notnull2 [, ...]])|
FOREIGN KEY [NO INDEX] (ref1 [, ref2 [, ...]])REFERENCES foreigntable [(foreignfield1 [, foreignfield2 [, ...]])]}
[ON UPDATE CASCADE | SET NULL]
[ON DELETE CASCADE | SET NULL]}

子句可分为以下几个部分

部分 说明
name 欲创建的条件的名称。
primary1, primary2 被指定为主键.的栏位名。
unique1, unique2 欲设计成为唯一键的一个或多个栏位之名称。
notnull1, notnull2 被限制为非 Null 值的栏位的名称。
ref1, ref2 涉及到另一个表中的栏位的外部键栏位名
foreigntable 包含由外部栏位注明的栏位的外部表名。
foreignfield1, foreignfield2 由 ref1、ref2 指定的 foreigntable 中的栏位的名称。如果引用的栏位是 foreigntable 的主键,则可省略此子句。
说明
紧接在栏位的数据类型规格之后,在 ALTER TABLE 或 CREATE TABLE 语句的栏位定义子句中,使用单一栏位条件之语法。
只要在 ALTER TABLE 或 CREATE TABLE 语句的栏位定义子句之外使用保留字 CONSTRAINT,就可以使用多重栏位条件之语法。

将栏位设计为如下的条件类型之一

可以使用 UNIQUE 保留字将栏位设计为唯一键。这意味着在同一个表中没有两个记录的这个栏位的值是相同的。可以强制任何栏位或栏位列表为唯一的。如果多重栏位条件被设计成唯一键,在索引之中的所有栏位的组合值必须也是唯一的,即使在这些栏位之中有两个或两个以上的记录有相同的值。
可以用 PRIMARY KEY 保留字,将表中的栏位或一组栏位设计为主键。在主键之中所有的值必须是唯一的,且不可为 Null,一个表只能有一个主键。

注意

在一个已经设有主键的表中,不能再设定 PRIMARY KEY 条件,否则会发生错误。
您可以使用 FOREIGN KEY 保留字将一个栏位设定为外部键。如果外部表的主键是由一个以上的栏位所组成,则必须使用多重栏位条件定义,列出全部的引用栏位、外部表名、以及以列出引用栏位相同的顺序在外部表中列出引用栏位的名称。若所引用的栏位是外部表的主键,则无须指定所引用的栏位。根据默认,资料库引擎在认为外部表的主键是所引用栏位的情况下执行操作。
外部键条件限定具体的活动在一个相应的主键值被改变时来执行
你可以指定外部表上执行的活动,此活动基于一个在定义了CONSTRAINT的表中主键上执行的相应的活动。例如,考虑以下对“客户”表的定义
CREATE TABLE Customers (CustId INTEGER PRIMARY KEY, CLstNm NCHAR VARYING (50))
考虑表的以下定义,定义外部键与Customers表的主键关係的顺序为
CREATE TABLE Orders (OrderId INTEGER PRIMARY KEY, CustId INTEGER, OrderNotes NCHAR VARYING (255), CONSTRAINT FKOrdersCustId FOREIGN KEY (CustId) REFERENCES Customers ON UPDATE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE 和 ON DELETE CASCADE 子句都定义于外部键上。 ON UPDATE CASCADE 子句的含义是如果用户的标识符(CustId)在用户表中更新,此更新将通过顺序表级联。各个含有相应用户标识符值的顺序随着新值自动更新。 ON DELETE CASCADE 子句的含义是如果一个用户被从用户表中删除,顺序表中所有包含同样用户标识符值的位序也会被删除。
考虑到表中下列不同的定义,用 SET NULL 活动代替CASCADE活动的顺序为
CREATE TABLE Orders (OrderId INTEGER PRIMARY KEY, CustId INTEGER, OrderNotes NCHAR VARYING (255), CONSTRAINT FKOrdersCustId FOREIGN KEY (CustId) REFERENCES Customers ON UPDATE SET NULL ON DELETE SET NULL
ON UPDATE SET NULL 子句的含义是如果用户的标识符 (CustId) 在用户表中更新,顺序表中相应的外部键值将会被自动设为 NULL。相似地,ON DELETE SET NULL 子句的含义是如果一个用户被从用户表中删除,顺序表中所有相应的外部键将会被自动设为NULL。
为阻止外部键索引的自动生成,可使用变址器 NO INDEX。这一形式的外部键定义仅用于经常要複製形成索引值的情况。在外部键索引中的数值经常被複製的场合,使用索引不如直接进行表搜寻有效。对这种索引和表中插入和删除的行列的维护会降低性能,没有任何好处。
上一篇:God Lie 下一篇:CoCo都可茶饮(城隍店)

Copyright@2015-2025 www.aizhengw.cn 癌症网版板所有