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

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

ID:24601177

大小:53.00 KB

页数:4页

时间:2018-11-15

mysql外键-数据库新手入门之mysql中如何定义外键--_第1页
mysql外键-数据库新手入门之mysql中如何定义外键--_第2页
mysql外键-数据库新手入门之mysql中如何定义外键--_第3页
mysql外键-数据库新手入门之mysql中如何定义外键--_第4页
资源描述:

《mysql外键-数据库新手入门之mysql中如何定义外键--》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、MySQL外键:数据库新手入门之MySQL中如何定义外键>>  定义数据表  假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息。用来保存整机产品信息的表叫做Pc;用来保存配件供货信息的表叫做Parts。  在Pc表中有一个字段,用来描述这款电脑所使用的CPU型号;  在Parts表中相应有一个字段,描述的正是CPU的型号,我们可以把它想成是全部CPU的型号列表。  很显然,这个厂家生产的电脑,其使用的CPU一定是供货信息表(parts)中存在的型号。这时,两个表中就存在一种约束关系(constraint)Pc表中的CPU型号受到Parts表中型号的约束。

2、  首先我们来创建parts表:CREATETABLEparts(...字段定义...,modelVARCHAR(20)NOTNULL,...字段定义...);  接下来是Pc表:CREATETABLEpc(...字段定义...,cpumodelVARCHAR(20)NOTNULL,...字段定义...};  设置索引  若要设置外键,在参照表(referencingtable,即Pc表)和被参照表(referencedtable,即parts表)中,相对应的两个字段必须都设置索引(index)。  对Parts表:  ALTERTABLEpartsADDINDE

3、Xidx_model(model);  这句话的意思是,为parts表增加一个索引,索引建立在model字段上,给这个索引起个名字叫idx_model。  对Pc表也类似:  ALTERTABLEpcADDINDEXidx_cpumodel(cpumodel);  事实上这两个索引可以在创建表的时候就设置。这里只是为了突出其必要性。  定义外键  下面为两张表之间建立前面所述的那种约束。因为pc的CPU型号必须参照parts表中的相应型号,所以我们将Pc表的cpumodel字段设置为外键(FOREIGNKEY),即这个键的参照值来自于其他表。ALTERTABLEp

4、cADDCONSTRAINTfk_cpu_modelFOREIGNKEY(cpumodel)REFERENCESparts(model);  第一行是说要为Pc表设置外键,给这个外键起一个名字叫做fk_cpu_model;第二行是说将本表的cpumodel字段设置为外键;第三行是说这个外键受到的约束来自于Parts表的model字段。  这样,我们的外键就可以了。如果我们试着CREATE一台Pc,它所使用的CPU的型号是Parts表中不存在的,那么MySQL会禁止这台PC被CREATE出来。  级联操作  考虑以下这种情况:  技术人员发现,一个月之前输入到par

5、ts表中的某个系列的cpu(可能有很多款)的型号全都输错了一个字母,现在需要改正。我们希望的是,当parts表中那些ReferencedColumn有所变化时,相应表中的ReferencingColumn也能自动更正。  可以在定义外键的时候,在最后加入这样的关键字:  ONUPDATECASCADE;即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫级联操作。:)  如果把这语句完整的写出来,就是:ALTERTABLEpcADDCONSTRAINTfk_cpu_modelFOREIGNKEY(cpumodel)REFERENCESparts(mo

6、del)ONUPDATECASCADE;  除了CASCADE外,还有RESTRICT(禁止主表变更)、SETNULL(子表相应字段设置为空)等操作。>>>>这篇文章来自..,。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。