mysql存储引擎之------InnoDB
 记住先创建需要的索引。你也可以用ALTER TABLE往一个表添加一个自引用外键约束。 
InnoDB也支持使用ALTER TABLE来移除外键:  
ALTER TABLE yourtablename DROP FOREIGN KEY fk_symbol; 当年创建一个外键之时,如果FOREIGN KEY子句包括一个CONSTRAINT名字,你可以引用那个名字来移除外键。另外,当外键被创建之时,fk_symbol值被InnoDB内部保证。当你想要移除一个外键之时,要找出标记,请使用SHOW CREATE TABLE语句。例子如下:  
mysql> SHOW CREATE TABLE ibtest11c\G *************************** 1. row ***************************        Table: ibtest11c Create Table: CREATE TABLE `ibtest11c` (   `A` int(11) NOT NULL auto_increment,   `D` int(11) NOT NULL default '0',   `B` varchar(200) NOT NULL default '',   `C` varchar(175) default NULL,   PRIMARY KEY  (`A`,`D`,`B`),   KEY `B` (`B`,`C`),   KEY `C` (`C`),   CONSTRAINT `0_38775` FOREIGN KEY (`A`, `D`) REFERENCES `ibtest11a` (`A`, `D`) ON DELETE CASCADE ON UPDATE CASCADE,   CONSTRAINT `0_38776` FOREIGN KEY (`B`, `C`) REFERENCES `ibtest11a` (`B`, `C`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=INNODB CHARSET=latin1 1 row in set (0.01 sec)   mysql> ALTER TABLE ibtest11c DROP FOREIGN KEY 0_38775; InnoDB解析程序允许你在FOREIGN KEY ... REFERENCES ...子句中用`(backticks)把表和列名名字围起来。InnoDB解析程序也考虑到lower_case_table_names系统变量的设置。  
InnoDB返回一个表的外键定义作为SHOW CREATE TABLE语句输出的一部分:  
SHOW CREATE TABLE tbl_name; 从这个版本起,mysqldump也将表的正确定义生成到转储文件中,且并不忘记外键。  
你可以如下对一个表显示外键约束: 
SHOW TABLE STATUS FROM db_name LIKE 'tbl_name'; 外键约束被列在输出的Comment列。 
当执行外键检查之时,InnoDB对它照看着的子或父记录设置共享的行级锁。InnoDB立即检查外键约束,检查不对事务提交延迟。  
要使得对有外键关系的表重新载入转储文件变得更容易,mysqldump自动在转储输出中包括一个语句设置FOREIGN_KEY_CHECKS为0。这避免在转储被重新装载之时,与不得不被以特别顺序重新装载的表相关的问题。也可以手动设置这个变量:  
mysql> SET FOREIGN_KEY_CHECKS = 0; mysql> SOURCE dump_file_name; mysql> SET FOREIGN_KEY_CHECKS = 1; 如果转储文件包含对外键是不正确顺序的表,这就以任何顺序导入该表。这样也加快导入操作。设置FOREIGN_KEY_CHECKS为0,对于在LOAD DATA和ALTER TABLE操作中忽略外键限制也是非常有用的。  
InnoDB不允许你删除一个被FOREIGN KEY表约束引用的表,除非你做设置SET FOREIGN_KEY_CHECKS=0。当你移除一个表的时候,在它的创建语句里定义的约束也被移除。  
如果你重新创建一个被移除的表,它必须有一个遵从于也引用它的外键约束的定义。它必须有正确的列名和类型,并且如前所述,它必须对被引用的键有索引。如果这些不被满足,MySQL返回错误号1005 并在错误信息字符串中指向errno 150。  
  本新闻共 6页,当前在第 6页   1  2  3  4  5  6   |