mysql innodb 外键关联约束实例
2010-07-16 09:32
197 查看
MYSQL INNODB
关联的表必须都是innodb
在已曾在的表中创建外键
alter table 外键所在的表名 add constraint 外键名 foreign key(外键所在的列名) references 对应主键所在表名(主键所在列名);
alter table 外键所在的表名 add constraint 外键名 foreign key(外键所在的列名) references 对应主键所在表名(主键所在列名) ON DELETE CASCADE ON UPDATE NO ACTION;
删除外键
alter table tablename drop foreign key namefk;
外键的作用:
保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值!
例如:
a b 两个表
a表中存有 客户号,客户名称
b表中存有 每个客户的订单
有了外键后
你只能在确信b 表中没有客户x的订单后,才可以在a表中删除客户x
建立外键的前提: 本表的列必须与外键类型相同(外键必须是外表主键)。
指定主键关键字: 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列 当外键的值删除 本表中对应的列筛除 当外键的值改变本表中对应的列值改变。
例子:
products 和 serial是一对多的关系
serial.pid字段是外键,products.id字段是外表对应的主键
--
-- 表的结构 `products`
--
DROP TABLE IF EXISTS `products`;
CREATE TABLE IF NOT EXISTS `products` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(55) collate utf8_unicode_ci default NULL,
PRIMARY KEY (`id`),
KEY `name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=4 ;
--
-- 导出表中的数据 `products`
--
INSERT INTO `products` (`id`, `name`) VALUES
(3, 'ccc');
--
-- 表的结构 `serial`
--
DROP TABLE IF EXISTS `serial`;
CREATE TABLE IF NOT EXISTS `serial` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(55) collate utf8_unicode_ci default NULL,
`pid` int(11) default NULL,
PRIMARY KEY (`id`),
KEY `name` (`name`),
KEY `pid` (`pid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=5 ;
--
-- 导出表中的数据 `serial`
--
INSERT INTO `serial` (`id`, `name`, `pid`) VALUES
(2, 'reyqergtsdgasdg', 3),
(3, 'qerwetsdfsdg', 3);
--
-- 限制导出的表
--
--
-- 限制表 `serial`
--
ALTER TABLE `serial`
ADD CONSTRAINT `pidfk` FOREIGN KEY (`pid`) REFERENCES `products` (`id`) ON UPDATE NO ACTION;
关联的表必须都是innodb
在已曾在的表中创建外键
alter table 外键所在的表名 add constraint 外键名 foreign key(外键所在的列名) references 对应主键所在表名(主键所在列名);
alter table 外键所在的表名 add constraint 外键名 foreign key(外键所在的列名) references 对应主键所在表名(主键所在列名) ON DELETE CASCADE ON UPDATE NO ACTION;
删除外键
alter table tablename drop foreign key namefk;
外键的作用:
保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值!
例如:
a b 两个表
a表中存有 客户号,客户名称
b表中存有 每个客户的订单
有了外键后
你只能在确信b 表中没有客户x的订单后,才可以在a表中删除客户x
建立外键的前提: 本表的列必须与外键类型相同(外键必须是外表主键)。
指定主键关键字: 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列 当外键的值删除 本表中对应的列筛除 当外键的值改变本表中对应的列值改变。
例子:
products 和 serial是一对多的关系
serial.pid字段是外键,products.id字段是外表对应的主键
--
-- 表的结构 `products`
--
DROP TABLE IF EXISTS `products`;
CREATE TABLE IF NOT EXISTS `products` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(55) collate utf8_unicode_ci default NULL,
PRIMARY KEY (`id`),
KEY `name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=4 ;
--
-- 导出表中的数据 `products`
--
INSERT INTO `products` (`id`, `name`) VALUES
(3, 'ccc');
--
-- 表的结构 `serial`
--
DROP TABLE IF EXISTS `serial`;
CREATE TABLE IF NOT EXISTS `serial` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(55) collate utf8_unicode_ci default NULL,
`pid` int(11) default NULL,
PRIMARY KEY (`id`),
KEY `name` (`name`),
KEY `pid` (`pid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=5 ;
--
-- 导出表中的数据 `serial`
--
INSERT INTO `serial` (`id`, `name`, `pid`) VALUES
(2, 'reyqergtsdgasdg', 3),
(3, 'qerwetsdfsdg', 3);
--
-- 限制导出的表
--
--
-- 限制表 `serial`
--
ALTER TABLE `serial`
ADD CONSTRAINT `pidfk` FOREIGN KEY (`pid`) REFERENCES `products` (`id`) ON UPDATE NO ACTION;
相关文章推荐
- mysql innodb 外键关联约束讲解
- hibernate 外键关联 不生成外键约束
- 主键约束、外键约束、唯一约束、检查约束、默认值约束实例
- oracle禁用外键关联约束
- 单向一对一唯一外键关联实例
- 主键约束、外键约束、唯一约束、检查约束、默认值约束实例
- 实例关联的外键对象不为空时保存出错
- hibernate一对一外键单向关联实例
- DataSet实例之建立数据表和主外键约束
- Hibernate一对一外键关联实现方法实例
- DataSet实例之建立数据表和主外键约束
- MariaDB数据库的外键约束实例详解
- plsql找外键约束关联的表的方法
- 力所能及之hibernate 外键关联 不生成外键约束
- Hibernate中one2one映射实例一(采用外键的单向关联)
- Hibernate之一对一外键关联
- sql查询指定表外键约束
- SQL外键约束
- Hibernate之一对多双向外键关联
- hibernate5(12)注解映射[4]一对一外键关联