phpMyAdmin里怎么设置外键?

phpMyAdmin里怎么设置外键?,第1张

1、登录phpmyadmin,找到要删除外键的数据库的表。如果是本地的话一般是localhost/phpmyadmin。

2、使用   SHOW CREATE TABLE at_article  查出表的结构,其中at_article是你要删除外键的表名。

3、查来之后,是一个简单的显示,点击“选项”,然后选择“完整内容”,然后点执行,就可以看到完整的表结构。

4、从最后一行里找到外键约束,其中fk_at_article_at_type为外键值。

5、删除外键ALTER TABLE at_article DROP FOREIGN KEY  fk_at_article_at_type。

6、如果外键字段不再使用,可以在表中删除外键的字段。

ON DELETE、ON UPDATE表示事件触发限制,可设参数:

RESTRICT(限制外表中的外键改动)

CASCADE(跟随外键改动)

SET NULL(设空值)

SET DEFAULT(设默认值)

NO ACTION(无动作,默认的)

数据库 mysql 建立外键的前提:本表的列必须与外键类型相同(外键

必须是外表主键)。

外键作用: 使两张表形成关联,外键只能引用外表中的列的值!

指定主键关键字: foreign key(列名)

引用外键关键字: references <外键表名>(外键列名)

事件触发限制: on delete 和on update , 可设参数cascade(跟随外键改

动), restrict(限制外表中的外键改动),set Null(设空值),set Default(设

默认值),[默认]no action

例如:

outTable 表主键 id 类型int

创建含有外键的表:

create table temp(

id int,

name char(20),

foreign key(id) references outTable(id) on delete cascade on update

cascade)

说明:把id 列设为外键参照外表 outTable 的id 列当外键的值删除

本表中对应的列删除当外键的值改变本表中对应的列值改变。

自己实践 才能完全了解外键的作用关键是:事件触发限制的作用

restrict 在没有删除引用id 的时候不允许删除背引用id

no action 在没有删除引用id 的时候不允许删除背引用id

cascade 级联删除

set null 在删除被引用id 的时候会把引用id 置为空

有时没有外键设置选项是怎么回事呢?是因为storage engine 的原因,

设置为ENGINE= InnoDB 就可以了。

用 phpmyadmin 怎么建MySQL 的外键

在 PHPMYADMIN 中暂时还没有见到所见即所得的外键定义方式.

你可以使用SQL指令去建立

语法如下:

ALTER TABLE 表名ADD FOREIGN KEY (字段名) REFERENCES

表名(字段名)

如果直接删除外键,会报错

首先先找到该外键的名称,FK_Relationship_77

先 *** 作删除外键名称

alter table tbl_products drop foreign key FK_Relationship_77

然后在 *** 作删除字段

alter table tbl_products drop column ProductLogicClassesId

下面是一个实例

首先,目前在产品环境可用的MySQL 版本(指4.0.x 和4.1.x)中,

只有 InnoDB 引擎才允许使用外键,所以,我们的数据表必须使用

InnoDB引擎。

下面,我们先创建以下测试用数据库表:

CREATE TABLE `roottb` (

`id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,

`data` VARCHAR(100) NOT NULL DEFAULT '',

PRIMARY KEY (`id`)

) TYPE=InnoDB

CREATE TABLE `subtb` (

`id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,

`rootid` INT(11) UNSIGNED NOT NULL DEFAULT '0',

`data` VARCHAR(100) NOT NULL DEFAULT '',

PRIMARY KEY (`id`),

INDEX (`rootid`),

FOREIGN KEY (`rootid`) REFERENCES roottb(`id`) ON DELETE

CASCADE

) TYPE=InnoDB

注意:

1、必须使用InnoDB引擎;

2、外键必须建立索引(INDEX);

3、外键绑定关系这里使用了“ ON DELETE CASCADE”,意思是如果

外键对应数据被删除,将关联数据完全删除,更多信息请参考MySQL

手册中关于InnoDB的文档;

好,接着我们再来插入测试数据:

INSERT INTO `roottb` (`id`,`data`)

VALUES ('1', 'test root line 1'),

('2', 'test root line 2'),

('3', 'test root line 3')

INSERT INTO `subtb` (`id`,`rootid`,`data`)

VALUES ('1', '1', 'test sub line 1 for root 1'),

('2', '1', 'test sub line 2 for root 1'),

('3', '1', 'test sub line 3 for root 1'),

('4', '2', 'test sub line 1 for root 2'),

('5', '2', 'test sub line 2 for root 2'),

('6', '2', 'test sub line 3 for root 2'),

('7', '3', 'test sub line 1 for root 3'),

('8', '3', 'test sub line 2 for root 3'),

('9', '3', 'test sub line 3 for root 3')

我们先看一下当前数据表的状态:

mysql>show tables

+----------------+

| Tables_in_test |

+----------------+

| roottb |

| subtb |

+----------------+

2 rows in set (0.00 sec)

mysql>select * from `roottb`

+----+------------------+

| id | data |

+----+------------------+

| 1 | test root line 1 |

| 2 | test root line 2 |

| 3 | test root line 3 |

+----+------------------+

3 rows in set (0.05 sec)

mysql>select * from `subtb`

+----+--------+----------------------------+

| id | rootid | data |

+----+--------+----------------------------+

| 1 | 1 | test sub line 1 for root 1 |

| 2 | 1 | test sub line 2 for root 1 |

| 3 | 1 | test sub line 3 for root 1 |

| 4 | 2 | test sub line 1 for root 2 |

| 5 | 2 | test sub line 2 for root 2 |

| 6 | 2 | test sub line 3 for root 2 |

| 7 | 3 | test sub line 1 for root 3 |

| 8 | 3 | test sub line 2 for root 3 |

| 9 | 3 | test sub line 3 for root 3 |

+----+--------+----------------------------+

9 rows in set (0.01 sec)

嗯,一切都正常,好,下面我们要试验我们的级联删除功能了。

我们将只删除roottb 表中id 为2 的数据记录,看看subtb 表中rootid

为2 的相关子纪录是否会自动删除:

mysql>delete from `roottb` where `id`='2'

Query OK, 1 row affected (0.03 sec)

mysql>select * from `roottb`

+----+------------------+

| id | data |

+----+------------------+

| 1 | test root line 1 |

| 3 | test root line 3 |

+----+------------------+

2 rows in set (0.00 sec)

mysql>select * from `subtb`

+----+--------+----------------------------+

| id | rootid | data |

+----+--------+----------------------------+

| 1 | 1 | test sub line 1 for root 1 |

| 2 | 1 | test sub line 2 for root 1 |

| 3 | 1 | test sub line 3 for root 1 |

| 7 | 3 | test sub line 1 for root 3 |

| 8 | 3 | test sub line 2 for root 3 |

| 9 | 3 | test sub line 3 for root 3 |

+----+--------+----------------------------+

6 rows in set (0.01 sec)

subtb 表中对应数据确实自动删除了,测试成功。

结论:在MySQL中利用外键实现级联删除成功!


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

原文地址: https://outofmemory.cn/bake/11701159.html

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

发表评论

登录后才能评论

评论列表(0条)

保存