视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Mysql外键约束_MySQL
2020-11-09 20:18:24 责编:小采
文档
Mysql集群创建外键,分为四种约束:no action,restrict,cascade,set null。如果表A的主关键字是表B中的字段,则该字段称为B的外键,表A称为主表,表B称为从表。外键是用来实现参照完整性的,不同的外键不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。

CASCADE: 从父表删除或更新且自动删除或更新子表中匹配的行。

·SET NULL: 从父表删除或更新行,并设置子表中的外键列为NULL。

·NO ACTION: 在ANSI SQL-92标准中,NO ACTION意味这不采取动作,就是如果有一个相关的外键值在被参考的表里,删除或更新主要键值的企图不被允许进行(Gruber, 掌握SQL, 2000:181)。 InnoDB拒绝对父表的删除或更新操作。

RESRICT:同no action。

环境模拟:

先来添加两张表:ta_resource和ta_resourcetime。

DROP TABLE IF EXISTS `ta_resource`;
CREATE TABLE `ta_resource` (
 `ResourceId` varchar() NOT NULL,
 `ResourcePId` varchar() DEFAULT NULL,
 `ResourceName` varchar() DEFAULT NULL,
 `Type` varchar() DEFAULT NULL,
 `Desc` varchar(512) DEFAULT NULL,
 `Priority` smallint(6) DEFAULT NULL,
 `IsFold` varchar(2) DEFAULT NULL,
 `IsUse` varchar(2) DEFAULT NULL,
 `URL` varchar() DEFAULT NULL,
 `Icon` varchar(512) DEFAULT NULL,
 `Css` varchar() DEFAULT NULL,
 `JavaScript` varchar() DEFAULT NULL,
 `TimeSpan` datetime DEFAULT NULL,
 `IsDefault` varchar(2) DEFAULT NULL,
 PRIMARY KEY (`ResourceId`)
) ENGINE=ndbcluster DEFAULT CHARSET=utf8;

-- ----------------------------
-- Table structure for `ta_resourcetime`
-- ----------------------------
DROP TABLE IF EXISTS `ta_resourcetime`;
CREATE TABLE `ta_resourcetime` (
 `TimeId` varchar() NOT NULL,
 `ResourceId` varchar() NOT NULL,
 `ResourceName` varchar() DEFAULT NULL,
 `RoleId` varchar() NOT NULL,
 `RoleName` varchar() DEFAULT NULL,
 `URL` varchar() DEFAULT NULL,
 `StartTime` datetime NOT NULL,
 `EndTime` datetime NOT NULL,
 `IsDeleted` varchar(2) DEFAULT NULL,
 `Desc` varchar(512) DEFAULT NULL,
 PRIMARY KEY (`TimeId`),
 KEY `ResourceId` (`ResourceId`),
 CONSTRAINT `resourceid` FOREIGN KEY (`ResourceId`) REFERENCES `ta_resource` (`ResourceId`) ON 
 DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=ndbcluster DEFAULT CHARSET=utf8;


1、no action时

这两个表中的外键使用的是ON DELETE NO ACTION ON UPDATE NO ACTION

如果更改数据时, ta_resource是主表,ta_resourcetime是从表。

更新数据时:可以修改主表,但是不可以修改从表的数据。

删除数据时:先删除从表,再删除主表。

2、cascade时

集群搭建完再插入数据库表时,在on delete 和on update 都使用cascade时遇到了这样的问题:不能添加外键约束。

之前以为是mysql集群不支持外键,在网上查了mysql集群该版本支持外键约束和师哥们讨论过这个问题,表示mysql集群支持外键约束。于是经过多次实践,找到出现这种问题的原因:mysql集群中支持使用cascade,但是on delete 和on update只能有一个使用cascade,另一个使用no action就可以。

3、内存不足

出现的问题:插入不进去数据,经过查询,是由于内存不足

解决方法:

在配置文件config.ini中对内存进行设置,主要对这几项进行设置:

MaxNoOfTables=10240

设置集群中最大表对象数量
MaxNoOfAttributes=500000

设置可在集群中定义的属性数量

MaxNoOfConcurrentTransactions=1000000
用于设定节点内可能的并发事务数
MaxNoOfConcurrentOperations=1000000
设置能同时出现在更新阶段或同时锁定的记录数
MaxNoOfOrderedIndexes=10240
设置有序索引的总数

如果不配置这些,mysql集群中会默认内存的大小,当内存满了以后就插不进去数据了。

下载本文
显示全文
专题