发布网友 发布时间:2022-04-23 03:44
共2个回答
懂视网 时间:2022-05-01 17:04
MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引。在创建索引的时候,可以指定在删除、更新父表时,对子表进行的相应操作,包括RESTRICT、NO ACTION、SET NULL和CASCADE。其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新;CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录;SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被SET NULL。
因为只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎。我所使用的版本是Mysql5.1版本的,过程如下:
创建数据库:
Create database test;
创建两个表,其中第一个表的”id”是第二个表(userinfo)的外键:
CREATE TABLE `user` (
`id` int(4) NOT NULL,
`sex` enum(‘f‘,‘m‘) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `userinfo` (
`sn` int(4) NOT NULL AUTO_INCREMENT,
`userid` int(4) NOT NULL,
`info` varchar(20) DEFAULT NULL,
PRIMARY KEY (`sn`),
KEY `userid` (`userid`),
CONSTRAINT `userinfo_ibfk_1` FOREIGN KEY (`userid`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
注意:
1、存储引擎必须使用InnoDB引擎;
2、外键必须建立索引;
3、外键绑定关系这里使用了“ ON DELETE CASCADE ” “ON UPDATE CASCADE”,意思是如果外键对应数据被删除或者更新时,将关联数据完全删除或者相应地更新。
mysql外键级联更新删除
标签:
热心网友 时间:2022-05-01 14:12
主键
外键
索引
定义:
唯一标识一条记录,不能有重复的,不允许为空
表的外键是另一表的主键,
外键可以有重复的,
可以是空值
该字段没有重复值,但可以有一个空值
作用:
用来保证数据完整性
用来和其他表建立联系用的
是提高查询排序的速度
个数:
主键只能有一个
一个表可以有多个外键
一个表可以有多个惟一索引
设置索引
若要设置外键,在参照表(pc表)
和被参照表(parts表)中,相对应的两个字段必须都设置索引(index)。
对parts表:
ALTER
TABLE
parts
ADD
INDEX
idx_model
(model);
这句话的意思是,为parts表增加一个索引,索引建立在model字段上,给这个索引起个名字叫idx_model。
对pc表也类似:
ALTER
TABLE
pc
ADD
INDEX
idx_cpumodel
(cpumodel);
定义外键
下面为两张表之间建立前面所述的那种“约束”。因为pc的CPU型号必须参照parts表中的相应型号,所以我们将pc表的cpumodel字段设置为“外键”(FOREIGN
KEY),即这个键的参照值来自于其他表。
ALTER
TABLE
pc
ADD
CONSTRAINT
fk_cpu_model
FOREIGN
KEY
(cpumodel)
REFERENCES
parts(model);
级联操作
级联更新:更新主键时,外键也随之更新。
可以在定义外键的时候,在最后加入这样的关键字:
ON
UPDATE
CASCADE;
即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫“级联”操作。
如果把这语句完整的写出来,就是:
ALTER
TABLE
pc
ADD
CONSTRAINT
fk_cpu_model
FOREIGN
KEY
(cpumodel)
REFERENCES
parts(model)
ON
UPDATE
CASCADE;
级联删除:删除主键时,外键也随之删除。
ALTER
TABLE
pc
ADD
CONSTRAINT
fk_cpu_model
FOREIGN
KEY
(cpumodel)
REFERENCES
parts(model)
ON
DELETE
CASCADE;
级联更新、删除:
on
update
cascade
on
delete
cascade