玩转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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: 设计高效合理的MySQL查询语句下一篇: MySql管理的一点心得
关于玩转MySQL中的外键约束的所有评论