MySQL删除外键定义的方法

MySQL删除外键定义的方法

2010-10-09 10:21 佚名 互联网 字号: T | T
一键收藏,随时查看,分享好友!

MySQL数据库中的外键如果我们不需要了,就可以删除掉外键定义,下文对该方法进行了详细的介绍,如果您感兴趣的话,不妨一看。

AD:WOT2014:用户标签系统与用户数据化运营培训专场

MySQL外键在定以后,如果我们不再需要这个外键,可以进行删除操作,下面就为您介绍MySQL删除外键定义的方法,供您参考。

不知道大家有没有发现,在定义外键的时候articles.member_id外键比articles.category_id子句多了一个CONSTRAINT fk_member ?
这个fk_member就是用来实现MySQL删除外键用的,如下所示:

   
   
  1. mysql> ALTER TABLE articles DROP FOREIGN KEY fk_member;  
  2. Query OK, 1 row affected (0.25 sec)  
  3. Records: 1    Duplicates: 0    Warnings: 0 

这样articles.member_id外键定义就被删除了,但是如果定义时没有指定CONSTRAINT fk_symbol (即外键符号)时该怎么实现MySQL删除外键呢?别急,没有指定时,MySQL会自己创建一个,可以通过以下命令查看:

   
   
  1. mysql> SHOW CREATE TABLE articles;  
  2. +———-+————————————+  
  3. | Table      | Create Table                         |  
  4. +———-+————————————+  
  5. | articles | CREATE TABLE `articles` (  
  6.     `article_id` int(11) unsigned NOT NULL auto_increment,  
  7.     `category_id` tinyint(3) unsigned NOT NULL,  
  8.     `member_id` int(11) unsigned NOT NULL,  
  9.     `title` varchar(255) NOT NULL,  
  10.     PRIMARY KEY    (`article_id`),  
  11.     KEY `category_id` (`category_id`),  
  12.     KEY `member_id` (`member_id`),  
  13.     CONSTRAINT `articles_ibfk_1` FOREIGN KEY (`category_id`) REFERENCES `categories` (`id`)  
  14. ENGINE=InnoDB DEFAULT CHARSET=latin1            |  
  15. +———-+————————————+  
  16. 1 row in set (0.01 sec)  
  17.  

可以看出articles.category_id的外键符号为articles_ibfk_1,因为就可以执行以下命令实现MySQL删除外键定义:

   
   
  1. mysql> ALTER TABLE articles DROP FOREIGN KEY articles_ibfk_1;  
  2. Query OK, 1 row affected (0.66 sec)  
  3. Records: 1    Duplicates: 0    Warnings: 0 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值