快速业务通道

玩转MySQL中的外键约束

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-18
rton''), (NULL, 1, ''Commenting first blog entry'', ''Rose Wilson'')  上面的代码,实际上模拟了读者Susan和Rose对我们的第一篇博客作出了评论的情况。假设现在我们要用另一篇文章来更新第一篇博客。当然,这种情况是有可能发生的。

  在这种情况下,为了维护数据库的一致性,comments表也必须进行相应的更新,要么通过手工方式更新,或者通过处理数据层的应用程序进行更新。就本例而言,我们将使用SQL命令来完成更新,具体如下所示:

UPDATE blogs SET id = 2, title = ''Title of the first blog entry'', content = ''Content of the first blog entry'', author = ''John Doe'' WHERE id = 1

UPDATE comments SET blog_id = 2 WHERE blod_id = 1  如前所述,因为第一篇博客的数据项的内容已经更新,所以comments表也必须反映出此变化才行。当然,现实中这个更新操作应该在应用程序层完成,而非手工进行,这就意味着这个逻辑必须使用服务器端语言来实现。

  为了完成这个操作,对于PHP来说可以通过一个简单的子过程即可,但是实际上,如果使用了外键约束的话,对comments表的更新操作完全可以委托给数据库。

  就像文章前面所说的那样,InnoDB MySQL表对这个功能提供了无缝地支持。所以,后面部分我们会使用外键约束重新前面的示例代码。

  四、数据库的级联更新

  下面,我们将利用外键约束和InnoDB表(而非默认的MyISAM类型)来重新构建前面的示例代码。为此,首先要重新定义这两个示例表,以便它们可以使用特定的数据库引擎。为此,可以使用如下所示的SQL代码:

DROP TABLE IF EXISTS `test`.`blogs`;

CREATE TABLE `test`.`blogs` (

`id` INT(10) UNSIGNED AUTO_INCREMENT,

`title` TEXT,

`content` TEXT,

`author` VARCHAR(45) DEFAULT NULL,

PRIROSE KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;


DROP TABLE IF EXISTS `test`.`comments`;

CREATE TABLE `test`.`comments` (

`id` INT(10) UNSIGNED AUTO_INCREMENT,

`blog_id` INT(10) UNSIGNED DEFAULT NULL,

`comment` TEXT,

`author` VARCHAR(45) DEFAULT NULL,

PRIROSE KEY (`id`),

KEY `blog_ind` (`blog_id`),

CONSTRAINT `comments_ibfk_1` FOREIGN KEY (`blog_id`) REFERENCES `blogs` (`id`) ON UPDATE CASCADE

) ENGINE=InnoDB DEFAULT CHARSET=utf8;   这里的代码与之前的代码相比,一个明显的不同之处在于现在的这两个表使用了

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号