控件中国网现已改版,您看到的是老版本网站的镜像,系统正在为您跳转到新网站首页,请稍候.......
中国最专业的商业控件资讯网产品咨询电话:023-67870900 023-67871946
产品咨询EMAIL:SALES@COMPONENTCN.COM

数据库新手入门之MySQL中如何定义外键

作者:未知 出处:不详 2010年01月27日 阅读:

定义数据表

假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息。用来保存整机产品信息的表叫做  Pc;用来保存配件供货信息的表叫做  Parts。

在  Pc  表中有一个字段,用来描述这款电脑所使用的  CPU  型号;
在  Parts  表中相应有一个字段,描述的正是  CPU  的型号,我们可以把它想成是全部  CPU  的型号列表。
很显然,这个厂家生产的电脑,其使用的  CPU  一定是供货信息表(parts)中存在的型号。这时,两个表中就存在一种约束关系(constraint)——Pc  表中的  CPU  型号受到  Parts  表中型号的约束。

首先我们来创建  parts  表:

以下为引用的内容:

CREATE TABLE parts (

            ... 字段定义 ...,

            model VARCHAR(20) NOT NULL,

            ... 字段定义 ...

            );

接下来是  Pc  表:

以下为引用的内容:

CREATE TABLE pc (

            ... 字段定义 ...,

            cpumodel VARCHAR(20) NOT NULL,

            ... 字段定义 ...

            };

设置索引

若要设置外键,在参照表(referencing table,即  Pc  表) 和被参照表 (referenced table,即parts  表) 中,相对应的两个字段必须都设置索引(index)。

对  Parts  表:
ALTER TABLE parts ADD INDEX idx_model (model);
这句话的意思是,为  parts  表增加一个索引,索引建立在  model  字段上,给这个索引起个名字叫  idx_model。
对  Pc  表也类似:
ALTER TABLE pc ADD INDEX idx_cpumodel (cpumodel);
事实上这两个索引可以在创建表的时候就设置。这里只是为了突出其必要性。

定义外键
下面为两张表之间建立前面所述的那种“约束”。因为  pc  的  CPU  型号必须参照  parts  表中的相应型号,所以我们将  Pc  表的  cpumodel  字段设置为“外键”(FOREIGN KEY),即这个键的参照值来自于其他表。

以下为引用的内容:

ALTER TABLE pc ADD CONSTRAINT fk_cpu_model

            FOREIGN KEY (cpumodel)

            REFERENCES parts(model);

第一行是说要为  Pc  表设置外键,给这个外键起一个名字叫做  fk_cpu_model;第二行是说将本表的  cpumodel  字段设置为外键;第三行是说这个外键受到的约束来自于  Parts  表的  model  字段。

这样,我们的外键就可以了。如果我们试着  CREATE  一台  Pc,它所使用的  CPU  的型号是Parts  表中不存在的,那么  MySQL  会禁止这台  PC  被  CREATE  出来。

级联操作

考虑以下这种情况:

技术人员发现,一个月之前输入到  parts  表中的某个系列的  cpu  (可能有很多款)的型号全都输错了一个字母,现在需要改正。我们希望的是,当  parts  表中那些  Referenced Column  有所变化时,相应表中的  Referencing Column  也能自动更正。

可以在定义外键的时候,在最后加入这样的关键字:

ON UPDATE CASCADE; 即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫“级联”操作。

如果把这语句完整的写出来,就是:

以下为引用的内容:

ALTER TABLE pc ADD CONSTRAINT fk_cpu_model

            FOREIGN KEY (cpumodel)

            REFERENCES parts(model)

            ON UPDATE CASCADE;

除了  CASCADE  外,还有  RESTRICT(禁止主表变更)、SET NULL(子表相应字段设置为空)等操作。
                                                          
                                                            【注:本文由控件中国网转载】

热推产品

  • ActiveReport... 强大的.NET报表设计、浏览、打印、转换控件,可以同时用于WindowsForms谀坔攀戀Forms平台下......
  • AnyChart AnyChart使你可以创建出绚丽的交互式的Flash和HTML5的图表和仪表控件。可以用于仪表盘的创......
首页 | 新闻中心 | 产品中心 | 技术文档 | 友情连接 | 关于磐岩 | 技术支持中心 | 联系我们 | 帮助中心 Copyright-2006 ComponentCN.com all rights reserved.重庆磐岩科技有限公司(控件中国网) 版权所有 电话:023 - 67870900 传真:023 - 67870270 产品咨询:sales@componentcn.com 渝ICP备12000264号 法律顾问:元炳律师事务所 重庆市江北区塔坪36号维丰创意绿苑A座28-5 邮编:400020
在线客服
在线客服系统
在线客服
在线客服系统