数据库 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中利用外键实现级联删除成功!

mysql怎么设主键和外键_MySQL主键外键设定方法相关推荐

  1. mysql主键和唯一索引_mysql 主键和唯一索引的区别

    主键是一种约束,唯一索引是一种索引,两者在本质上是不同的. 主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键. 唯一性索引列允许空值,而主键列不允许为空值. 主键列在创建时,已经默认为非空 ...

  2. oracle和mysql主键有什么不同_mysql 主键与oracle 的不同

    InnoDB默认创建的主键索引是聚簇索引(Clustered Index),其它索引都属于辅助索引(Secondary Index),也被称为二级索引或非聚簇索引. 我们使用一个 表来详细说明 商品表 ...

  3. mysql中外键设置级联删除_MySQL中利用外键实现级联删除、更新

    MySQL中利用外键实现级联删除.更新 MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在 创建索引的时候,可以指 ...

  4. mysql主键是非空吗_mysql主键非空约束怎么设置?

    mysql主键约束 主键(PRIMARY KEY)的完整称呼是"主键约束",是 MySQL 中使用最为频繁的约束.一般情况下,为了便于 DBMS 更快的查找到表中的记录,都会在表中 ...

  5. mysql主键索引需要创建_mysql主键还需要建立索引吗?

    mysql主键不需要建立索引,主键具备索引的功能:当创建或设置主键的时候,mysql会自动添加一个与主键对应的唯一索引,不需要再做额外的添加.数据库管理系统对于主键会自动生成唯一索引,所以主键是一个特 ...

  6. mysql主键干嘛的_mysql主键是什么?

    在mysql中,主键全称"主键约束",是一个列或多列的组合,其值能唯一地标识表中的每一行,通过它可强制表的实体完整性:主键的作用是确定该数据的唯一性,主要是用于和其他表的外键关联, ...

  7. mysql主键自增长空缺_Mysql 主键自增长auto_increment问题分析

    本节内容: Mysql 主键自增长 在mysql数据库中,主键由auto_increment实现自增长,若自定义函数来表示auto_increment的话可以如下: 复制代码 代码示例: create ...

  8. mysql索引类型和区别是什么意思_mysql主键索引和普通索引之间的区别是什么

    索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.MySQL提供多种索引类型供选择:普通索引 .唯一性索引.主键索引 .全文索引等等.下面本篇文章就来给大家介绍一下主键索 ...

  9. mysql外键设置不成功_MySQL数据库建立外键失败的原因总结

    在MySQL数据库创建外键时,经常会发生一些错误,这是一件很令人头疼的事.一个典型的错误就是:Can't create table... 的错误.在很多实例中,这种错误的发生都是因为mysql一直以来 ...

  10. mysql主主和F5高可用_MYSQL 主主热备高可用方案与实现

    咱们选择主主互热备作生产环境MYSQL高可用方案,该方案的优势是在压力大的时候,仍然能够经过设置负载均衡来作业务分发.并且最重要的是配置简单,两份配置都同样,改个IP就能够 就喜欢简单的东西.mysq ...

最新文章

  1. redhat5.5安装oracle11g的补丁包,在64位redhat5.5上面安装oracle 11g
  2. .NET Core ASP.NET Core 1.0在Redhat峰会上正式发布
  3. Spring Getting Started (1):构建一个RESTful的web服务
  4. 美团点评基于 Flink 的实时数仓平台实践
  5. 在Javascript中 声明时用var与不用var的区别,== 和 ===的区别
  6. TCP/IP总结(4)TCP 之数据包格式
  7. 练习2.13 不用库函数,写一个高效计算ln N的C函数
  8. 【QQ输入法】QQ输入法-剪切板 释放内存
  9. 卡布教你:脸上长痘痘平时要注意什么呢
  10. 使用JavaScript弹出Confirm对话框
  11. centos7 安装nginx
  12. ORA-04043: 对象 dba_data_files 不存在 BUG
  13. DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
  14. java学习血泪史目录
  15. Python计算水仙花数
  16. od 调试java_OD调试初步概念——修改窗口标题
  17. mysql varbinary 插入_Mysql中如何插入VarBinary二进制类型?
  18. 显卡更新显示计算机无法识别,电脑无法识别独立显卡
  19. whisper客服源码_以太坊源码分析—Whisper
  20. python程序怎么给别人运行_如何把自己写的python程序给别人用

热门文章

  1. oracle自我评价简历,程序员简历自我评价
  2. iOS性能优化-列表卡顿
  3. 马尔可夫链 以及 隐马尔可夫模型(HMM)
  4. FFmpeg —— 录制windows系统声音(附源码)
  5. asp.net 与donet(.net)的区别
  6. 文档数据库与关系数据库的比较
  7. matlab imfilter与fft,imfilter与fspecial
  8. 机器人——人类工作和生活的助手(科普)
  9. 数据仓库:金融/银行业主题层划分方案
  10. storm启动报错,storm-ui界面显示不正常