MySQL零散笔记--外键_MySQL

WBOY
リリース: 2016-06-01 13:51:27
オリジナル
967 人が閲覧しました

Mysql外键

References: 《浅谈MySQL外键》《mysql创建外键关联》

MySQL中“键”和“索引”的定义相同, 所以外键和主键一样也是索引的一种。不同的是MySQL会自动为所有表的主键进行索引,但是外键字段必须由用户进行明确的索引。//查看Mysql手册发现从MySQL 4.1.2开始会自动建立这个INDEX

创建外键的实例代码:员工和工资表:

/*
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
建立员工表
ログイン後にコピー
*/
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
create table employees ( 
ログイン後にコピー
id int(5) not null auto_increment , 
ログイン後にコピー
name varchar(8) not null, 
ログイン後にコピー
ログイン後にコピー
primary key (id)
ログイン後にコピー
) 
ログイン後にコピー
type=innodb;
ログイン後にコピー
 
ログイン後にコピー
ログイン後にコピー
/*
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
建立工资表
ログイン後にコピー
*/
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
create table payroll( 
ログイン後にコピー
id int(5) not null, 
ログイン後にコピー
emp_id int(5) not null, 
ログイン後にコピー
name varchar(8) not null, 
ログイン後にコピー
ログイン後にコピー
payroll float(4,2) not null, 
ログイン後にコピー
primary key(id), 
ログイン後にコピー
index emp_id (emp_id),
ログイン後にコピー
foreign key (emp_id) references employees (id)
ログイン後にコピー
)
ログイン後にコピー
type = innodb;
ログイン後にコピー

参照完整性(Referentialintegrity)通常通过外键(foreign key)的使用而被广泛应用,在MySQL中通过新的InnoDB列表引擎支持。为了建立两个MySQL表之间的一个外键关系,必须满足以下三种情况:

* 两个表必须是InnoDB表类型。  

* 使用在外键关系的域必须为索引型(Index)。  

* 使用在外键关系的域必须与数据类型相似。

怪不得我试着创建带外键的表的时候出错呢,原来是之前的表不是InnoDB类型,果断该表表的类型:

ALTER TABLE table-name TYPE=INNODB;

居然有Warning。 show warnings之后发现原来是 “The syntax 'TYPE=storage_engine' is deprecated and will be removed in MySQL 6.0. Please use 'ENGINE=storage_engine' instead”  TYPE已经OUT啦~以后要用Engine了嗯

关于表类型(type/engine)的介绍,可以在这里找到:

《浅谈MySQL表类型》,《MySQL engine/type类型InnoDB/MYISAM/MERGE/BDB/HEAP的区别》

注意事项:

  • 关系中的所有表必须是innoDB表,在非InnoDB表中,MySQL将会忽略FOREIGN KEY…REFERENCES修饰符。
  • 用于外键关系的字段必须在所有的参照表中进行明确地索引,InnoDB不能自动地创建索引。
  • 在外键关系中,字段的数据类型必须相似,这对于大小和符号都必须匹配的整数类型尤其重要。
  • 即使表存在外键约束,MySQL还允许我们删除表,并且不会产生错误(即使这样做可能会破坏更早创建的外键)

 

删除外键方法:

ALTER TABLE table-name DROP FOREIGN KEY key-id;
ログイン後にコピー

这里有一个概念,这个外键的id是啥玩意?我们可以通过SHOW CREATE TABLE 命令来获得key-id的值。

/*
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
显示建表结构语句,key-id为payroll_ibfk_1
ログイン後にコピー
*/
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
show create table payroll /G
ログイン後にコピー
/*
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
*************************** 1. row ***************************
ログイン後にコピー
       Table: payroll
ログイン後にコピー
Create Table: CREATE TABLE `payroll` (
ログイン後にコピー
  `id` int(5) NOT NULL,
ログイン後にコピー
  `emp_id` int(5) NOT NULL,
ログイン後にコピー
  `name` varchar(8) NOT NULL,
ログイン後にコピー
  `payroll` float(4,2) NOT NULL,
ログイン後にコピー
  PRIMARY KEY (`id`),
ログイン後にコピー
  KEY `emp_id` (`emp_id`),
ログイン後にコピー
  CONSTRAINT `payroll_ibfk_1` FOREIGN KEY (`emp_id`) REFERENCES `employees` (`id`)
ログイン後にコピー
) ENGINE=InnoDB DEFAULT CHARSET=latin1
ログイン後にコピー
1 row in set (0.00 sec)
ログイン後にコピー
 
ログイン後にコピー
ログイン後にコピー
*/
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

 

自动键更新和删除:

MySQL可能通过向FOREIGN KEY…REFERENCES 修饰符添加一个ON DELETE或ON UPDATE子句简化任务,它告诉了数据库在这种情况如何处理孤立任务。

关键字 含义
CASCADE 删除包含与已删除键值有参照关系的所有记录.就是删除外键记录
SET NULL 修改包含与已删除键值有参照关系的所有记录,使用NULL值替换(只能用于已标记为NOT NULL的字段)
RESTRICT 拒绝删除要求,直到使用删除键值的辅助表被手工删除,并且没有参照时(这是默认设置,也是最安全的设置)
NO ACTION 啥也不做

请注意,通过 ON UPDATE 和ON DELETE规则,设置MySQL能够实现自动操作时,如果键的关系没有设置好,可能会导致严重的数据破坏。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート