马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
一个相关的问题是第三方支持的资格问题,尽管直接来自厂商的支持和服务可以一定程度上减缓这个问题,但是,对于有的企业来说,通过强有力的本地化支持显然更有吸引力。mysql|数据|数据库参照完全性(Referentialintegrity)是数据库计划中一个主要的观点。在体系分歧的列表中,当数据库一切参照正当或非正当联系关系时城市触及到参照完全性。当参照完全性存在时,任何与不存在纪录的联系关系将变得有效化,由此可避免用户呈现各类毛病,从而供应更加正确和有用的数据库。 参照完全性一般经由过程外键(foreignkey)的利用而被普遍使用。久长以来,盛行工具开源RDBMSMySQL并没有撑持外键,缘故原由是这类撑持将会下降RDBMS的速率和功能。但是,因为良多用户对参照完全性的长处倍感乐趣,比来MySQL的分歧版本都经由过程新InnoDB列表引擎撑持外键。由此,在数据库构成的列表中坚持参照完全性将变得十分复杂。
<Palign=left> 为了创建两个MySQL表之间的一个外键干系,必需满意以下三种情形:
- 两个表必需是InnoDB表范例。
- 利用在外键干系的域必需为索引型(Index)。
- 利用在外键干系的域必需与数据范例类似。
例子是了解以上要点的最好办法。如表A所示,创建两个表,个中一个列出植物品种及响应的代码(表名为:species),另外一表列出植物园中的植物(表名为:zoo)。如今,我们想经由过程species联系关系这两个表,以是我们只必要承受和保留zoo表中包括species表中的正当植物的出口到数据库中。
表A - mysql>CREATETABLEspecies(idTINYINTNOTNULLAUTO_INCREMENT,nameVARCHAR(50)NOTNULL,PRIMARYKEY(id))ENGINE=INNODB;QueryOK,0rowsaffected(0.11sec)mysql>INSERTINTOspeciesVALUES(1,orangutan),(2,elephant),(3,hippopotamus),(4,yak);QueryOK,4rowsaffected(0.06sec)Records:4Duplicates:0Warnings:0mysql>CREATETABLEzoo(idINT(4)NOTNULL,nameVARCHAR(50)NOTNULL,FK_speciesTINYINT(4)NOTNULL,INDEX(FK_species),FOREIGNKEY(FK_species)REFERENCESspecies(id),PRIMARYKEY(id))ENGINE=INNODB;
复制代码 注重:关于非InnoDB表,FOREIGNKEY语句将被疏忽。 如今,fieldszoo.species与species.id之间存在一个外键干系。只要响应的zoo.specie与species.idfield的一个值相婚配,植物表中的出口才可被会见。以下的输入即演示了当你想输出一个HarryHippopotamus纪录,而利用到分歧法的species代码: - mysql>INSERTINTOzooVALUES(1,Harry,5);
- ERROR1216(23000):Cannotaddorupdateachildrow:aforeignkeyconstraintfails
复制代码 这里,MySQL核对species表以检察species代码是不是存在,假如发明不存在,就回绝该纪录。当你输出准确代码的,能够与以上做对照。- mysql>INSERTINTOzooVALUES(1,Harry,3);
- QueryOK,1rowaffected(0.06sec)
复制代码 这里,MySQL核对species表以检察species代码是不是存在,当发明存在,同意纪录保留在zoo表中。
为了删除一个外键干系,起首利用SHOWCREATETABLE找出InnoDB的外部标签,如表B所示:
表B
- +-------+---------------------------------------------------+
- |Table|CreateTable|
- +-------+---------------------------------------------------+
- |zoo|CREATETABLE`zoo`(
- `id`int(4)NOTNULLdefault0,
- `name`varchar(50)NOTNULLdefault,
- `FK_species`tinyint(4)NOTNULLdefault0,
- KEY`FK_species`(`FK_species`),
- CONSTRAINT`zoo_ibfk_1`FOREIGNKEY(`FK_species`)
- REFERENCES`species`(`id`)
- )ENGINE=InnoDBDEFAULTCHARSET=latin1|
- +-------+----------------------------------------------------+
复制代码 然后利用带有DROPFOREIGNKEY语句的ALTERTABLE命令,如以下: - mysql>ALTERTABLEzooDROPFOREIGNKEYzoo_ibfk_1;
- QueryOK,1rowaffected(0.11sec)
- Records:1Duplicates:0Warnings:0
复制代码 为了将一个外键增加到一个现成的表中,利用ADDFOREIGNKEY的ALTERTABLE语句指定符合的域作为一个外键: - mysql>ALTERTABLEzooADDFOREIGNKEY(FK_species)REFERENCESspecies(id);
- QueryOK,1rowsaffected(0.11sec)
- Records:1Duplicates:0Warnings:0
复制代码 如以上例子注释的,外键在捉摸数据出口毛病上起侧重要的感化,由此可创建更加健旺加倍集成的数据库。另外一方面值得提到的是,实行外键核实是外部材料处置的历程,且分歧表之间指定庞大的外部干系能够招致数据库的功能下落。以是,在参照完全性与功能思索之间找到均衡点相称主要,而利用外键就是可以确保功能与妥当之间的最优分离。
我希冀本期的有关外键的先容对你有所优点,你将会鄙人回的MySQL数据库计划中感觉到外键的优点。编程康乐!
事实上,在任何DBaaS中,解决方案提供商对如何管理物理资源都没有控制权,因此MySQL学习教程可能会发现由于DBaaS的局限性使得他们提供给客户的远远小于客户所期望的。 |