mysql数据库怎么删除一个表的外键

mysql数据库怎么删除一个表的外键,第1张

mysql删除外键语法:

alter table ss_accesscode drop foreign key 外键约束名称

外键定义:

如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。外键又称作外关键字。

作用:

保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。

可以确保数据完整性,有A表,B表。A的主码id是B的外码。这会产生2个情况,建立外码的时候会有“级联删除”和“受限删除”两种。外码的作用就体现在这两种功能上。

级联删除:当删除A里的数据后,B表内含该ID的行会自动由数据库删除。比如把某个学生ID删除了,那么他的分数之类的信息也要删除,留着也是垃圾数据。

受限删除:当要删除A内的数据,而B中又存在相关id的行,那么将不会执行删除,必须先把B内的这些行删除掉,再删除a里的数据。

更加详细的你可以去看MSsql联机丛书关于级联删除等的介绍。以下来自sql联机丛书:

ON

DELETE

NO

ACTION

指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚

DELETE。

ON

UPDATE

NO

ACTION

指定如果试图更新某行中的键值,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚

UPDATE。

CASCADE

允许在表间级联键值的删除或更新 *** 作,这些表的外键关系可追溯到执行修改的表。不能为任何具有

timestamp

列的外键和主键指定

CASCADE。

ON

DELETE

CASCADE

指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则也将删除所有包含那些外键的行。如果在目标表上也定义了级联引用 *** 作,则对从那些表中删除的行同样采取指定的级联 *** 作。

ON

UPDATE

CASCADE

指定如果试图更新某行中的键值,而该行的键值由其它表的现有行中的外键所引用,则所有外键值也将更新成为该键指定的新值。如果在目标表上也定义了级联引用 *** 作,则对在那些表中更新的键值同样采取指定的级联 *** 作。

上面就是外码约束的概念,希望你能明白它的作用。

有外键的情况下一般要先关掉外键的作用,然后删除,在开启。以为有外键的表一般不能删除的。如果是mysql数据库的话

先关闭外键

SET FOREIGN_KEY_CHECKS=0

然后删除

在开启

SET FOREIGN_KEY_CHECKS=1


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10829404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-11
下一篇 2023-05-11

发表评论

登录后才能评论

评论列表(0条)

保存