MySQL中如何定义外键

来源:asp之家 时间:2010-03-09 16:18:00 

假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息。用来保存整机产品信息的表叫做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出来。

标签:MySQL,定义,外键,MySQL外键
0
投稿

猜你喜欢

  • MySQL Explain命令用于查看执行效果

    2009-02-27 15:30:00
  • IE中jscript/javascript的条件编译

    2007-10-03 14:03:00
  • asp数据转换函数示例

    2008-04-13 06:52:00
  • 关于设计品质保证(DQA)的几点想法

    2007-11-16 16:55:00
  • CSS 3入门

    2009-04-19 13:00:00
  • 九宫格基本布局

    2009-06-18 18:36:00
  • 按钮上的内容

    2007-11-27 00:13:00
  • FCKeditor新版本发布,并更名为CKeditor

    2009-09-08 13:09:00
  • 如何把数据从SQL Server导出到Access或Excel中去?

    2009-11-02 20:26:00
  • MySQL安全性指南 (2)

    2010-07-26 13:26:00
  • Dreamweaver使用中的7个常见问题与解答

    2007-11-03 11:34:00
  • 网站注册那些事儿

    2010-01-05 16:49:00
  • 在ASP中如何使用类class

    2007-09-16 17:17:00
  • Javascript命名禁区[110407.updated]

    2011-04-28 09:48:00
  • 实例学习call、apply、callee用法

    2009-03-27 17:56:00
  • sqlserver 多表查询不同数据库服务器上的表

    2012-04-13 11:41:51
  • HTML中事件触发列表与解说

    2007-10-22 12:50:00
  • SQL 判断给定日期值(或时间段)所在星期的星期一和星期天的日期

    2011-10-24 20:14:52
  • IE8"开发人员工具"使用详解

    2009-03-26 12:51:00
  • Ajax的错误处理机制探讨

    2007-09-07 09:53:00
  • asp之家 网络编程 m.aspxhome.com