mysql外键关联问题

来源:未知 责任编辑:责任编辑 发表时间:2014-02-18 03:27 点击:
今儿继续再看老师给推荐的深入浅出mysql数据库开发这本书,看到innodb数据库的外键关联问题时,遇到了一个问题,书上写的是可以对父表进行修改,从而同步到子表的外键上去,可是自己的实验却是没有能够。
 
mysql> show create table country\G 
*************************** 1. row *************************** 
       Table: country 
Create Table: CREATE TABLE `country` ( 
  `country_id` smallint(5) unsigned NOT NULL auto_increment, 
  `country` varchar(50) NOT NULL, 
  `last_update` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, 
  PRIMARY KEY  (`country_id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 
1 row in set (0.01 sec) 
 
mysql> show create table city\G 
*************************** 1. row *************************** 
       Table: city 
Create Table: CREATE TABLE `city` ( 
  `city_id` smallint(5) unsigned NOT NULL auto_increment, 
  `city` varchar(50) NOT NULL, 
  `country_id` smallint(5) unsigned NOT NULL, 
  `last_update` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, 
  PRIMARY KEY  (`city_id`), 
  KEY `country_id` (`country_id`), 
  CONSTRAINT `city_ibfk_1` FOREIGN KEY (`country_id`) REFERENCES `country` (`country_id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 
1 row in set (0.00 sec) 
mysql> select * from city; 
+---------+----------+------------+---------------------+ 
| city_id | city     | country_id | last_update         | 
+---------+----------+------------+---------------------+ 
|       1 | hancheng |          1 | 2012-01-09 09:18:33 | 
+---------+----------+------------+---------------------+ 
1 row in set (0.01 sec) 
 
mysql> select * from country; 
+------------+---------+---------------------+ 
| country_id | country | last_update         | 
+------------+---------+---------------------+ 
|          1 | chen    | 2012-01-09 09:16:38 | 
+------------+---------+---------------------+ 
 
mysql> update country set country_id=100 where country_id=1; 
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`test/city`, CONSTRAINT `city_ibfk_1` FOREIGN KEY (`country_id`) REFERENCES `country` (`country_id`)) 
 
上面的问题是说因为有关联的存在,所以无法改变country_id这个字段。
然后自己又重新看了下书本,发现自己的sql语句中没有innodb的外键约束方式(cascade,set null,no action,restrict),感觉这就是自己出问题的地方。
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • mysql-mmm
  • mysqldump命令——MySQL数据库备份还原
  • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
  • 简简单单储存过程——循环一个select结果集
  • MySQL数据库十大优化技巧
  • Mysql安装笔记
  • Mysql主主复制架构配置
  • Mysql的Procedure 参数为NULL问题分析
  • MySQL Stmt预处理提高效率问题的小研究
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1