mysql cluster 外键_Mysql外键约束

Mysql集群创建外键,分为四种约束:no action,restrict,cascade,set null。如果表A的主关键字是表B中的字段,则该字段称为B的外键,表A称为主表,表B称为从表。外键是用来实现参照完整性的,不同的外键不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。

989fa6e93464e1b370602aa92f5246da.png

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(64) NOT NULL,

`ResourcePId` varchar(64) DEFAULT NULL,

`ResourceName` varchar(64) DEFAULT NULL,

`Type` varchar(64) DEFAULT NULL,

`Desc` varchar(512) DEFAULT NULL,

`Priority` smallint(6) DEFAULT NULL,

`IsFold` varchar(2) DEFAULT NULL,

`IsUse` varchar(2) DEFAULT NULL,

`URL` varchar(64) DEFAULT NULL,

`Icon` varchar(512) DEFAULT NULL,

`Css` varchar(64) DEFAULT NULL,

`JavaScript` varchar(64) 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(64) NOT NULL,

`ResourceId` varchar(64) NOT NULL,

`ResourceName` varchar(64) DEFAULT NULL,

`RoleId` varchar(64) NOT NULL,

`RoleName` varchar(64) DEFAULT NULL,

`URL` varchar(64) 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时遇到了这样的问题:不能添加外键约束。

011f57801b4762876b88863df506b5cb.png

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

3、内存不足

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

a7cf1d16406a9df9c6330f24e24a97df.png

解决方法:

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

MaxNoOfTables=10240

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

MaxNoOfAttributes=500000

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

MaxNoOfConcurrentTransactions=1000000

用于设定节点内可能的并发事务数

MaxNoOfConcurrentOperations=1000000

设置能同时出现在更新阶段或同时锁定的记录数

MaxNoOfOrderedIndexes=10240

设置有序索引的总数

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355047.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Map类集合遍历

转载于:https://www.cnblogs.com/Neil223/p/7275035.html

小米10解锁bl跳过168_2021年小米红米手机官方解锁BL详细教程+跳过168小时方法合集...

MIUI的解锁风控一直在改动,从之前的无需解锁到现在的168小时绑定限制,时至2021年我们再次重新整理下小米的解锁新规则以及小米解锁常见问题解决方法。比如大家常问的如果跳过168小时解锁时间限制等等小米解锁工具下载:http://miuirom.xiaomi.…

orderby排序慢_使用@OrderBy对Spring Data MongoDB集合进行排序

orderby排序慢这是关于调整和增强Spring Data MongoDB功能的第三篇文章。 这次,我发现我错过了一个JPA功能– OrderBy批注。 OrderBy指定在检索关联值时集合值关联的元素的顺序。 在本文中,我将展示如何使用Spring Data MongoDB使用OrderBy批注实现排序 …

细节取胜的javadoc

今个以为开发经验丰富的同事提出有个改动有问题,希望改一下。老前辈发话,心虚的紧,立即看了下,问题说是我的方法凝视中写了一个 ** doesnt ** 建议改为 does not 说这个生成javadoc有问题。咦。不禁困惑,这个写法我记得…

android实现箭头流程列表_Android开发关于ExpandableListView上下箭头左右显示的笔记...

释放双眼,带上耳机,听听看~!关键属性:android:layoutDirection""当安卓的layoutDirection “rtl” 时,箭头在右边显示布局:android:layout_width"match_parent"android:layout_height…

Java A的新本地变量类型推断

对于编程语言迷来说,新闻几乎比这更令人兴奋! 现在有一个状态为“候选”的本地变量类型推断的JEP 286 。 以及Brian Goetz的反馈请求,我很想邀请您参加: http : //mail.openjdk.java.net/pipermail/platform-jep-discuss/2016-Ma…

扩展kmp

拓展kmp是对KMP算法的扩展,它解决如下问题: 定义母串S,和字串T,设S的长度为n,T的长度为m,求T与S的每一个后缀的最长公共前缀 其中next数组表示T[i,m-1]和T的最长公共前缀 1 const int maxn100010; //字符…

linux中mysql导入数据库命令_linux下mysql数据库导入导出命令

首先linux 下查看mysql相关目录rootubuntu14:~# whereis mysqlmysql:/usr/bin/mysql—- mysql的运行路径/etc/mysql/usr/lib/mysql—– mysql的安装路径/usr/bin/X11/mysql/usr/share/mysql/usr/share/man/man1/mysql.1.gz此外还有一个:var/lib/mysql ——–mys…

转载:FilenameUtils的工具类

一、概述 这是一个Java操作文件的常用库,是Apache对java的IO包的封装,这里面有两个非常核心的类FilenameUtils跟FileUtils,其中FilenameUtils是对文件名操作的封装;FileUtils是文件封装,开发中对文件的操作,几乎都可以…

mysql 5.5.41 下载_MySQL 5.5.41/5.6.22 发布下载

MySQL 5.5.41 发布下载,此版本更新内容如下:编译改进移除了旧版本 Mac OS X 和 XCode 版本的CMake 工作区 (Bug #18510941)Previously, the MYSQL_MAINTAINER_MODE CMake option was turned on by default for debug builds and off for release builds…

envers_分代缓存和Envers

enversKonrad最近在我们公司的技术室中分享了有关如何完成缓存的有趣文章,这是一个大型的波兰社交网络nk.pl。 算法中的核心概念之一是分代缓存 (请参阅此处或此处 )。 基本思想是,对于缓存键,您使用一些特定于实体的字…

mysql ado.net 实体数据模型_Visual Studio2017中如何让Entity Framework工具【ADO.NET实体数据模型】支持MYSQL数据源...

熟悉Entity Framework应该对以下图片不陌生,他就是ADO.NET实体数据模型向导:可以将数据库的表自动生成模型类,或者创建Code First的模型文件。但是这个模型向导默认只显示微软自己的SQL Server数据源,如果想使用Mysql数据源&#…

ESP8266学习笔记6:ESP8266规范wifi连接操作

一、前言 我整理了从2015年至今关于ESP8266的学习笔记,梳理出来了开发环境、基础功能、进阶学习三大部分。方便自己和他人。可点此查看,欢迎交流。 之前在笔记4《ESP8266的SmartConfig》http://blog.csdn.net/iotisan/article/details/54849410中&#x…

使用Java 8进行分组,转换和归约

1.简介 在上一篇文章中 ,我写了关于如何使用流和分组对对象集合进行分组的文章。 这很有用,但不涵盖特定的用例。 例如,有时我们不仅需要对事物进行分组,还需要将结果转换为更合适的对象。 在这篇文章中,我们将学习如…

rhel6.9 yum安装mysql_在RHEL6.9上安装MySQL5.7

通过YUM方式安装MySQL 5.7Step 1、下载MySQL源wget dev.mysql.com/get/mysql-community-release-el6-5.noarch.rpmyum localinstall mysql-community-release-el6-5.noarch.rpmStep 2、配额yum源并安装MySQLyum-config-manager --disable mysql55-communityyum-config-manager …

正则表达式的\b与\B总结

\b 单词边界,是指单词与符号之间的边界,是一个位置,不是空格或字符。(这里单词可以是中文字符,英文字符,数字;   符号可以是中文符号,英文符号,空格,制表符&#xff0c…

php mysql 取最小值_php – 根据另一个值更新最小值 – MySql

循环遍历数组并检查num是否低于前一个数字.$data数组的示例:$data array([0] > array(id > 9267399, code > 5D:148, num > 64),[1] > array(id > 9267398, code > 5D:186, num > 71));–$array_to_add array();foreach($data AS $val) {…

关于flex,好像有12个属性非常重要

关于Flex,有12个属性非常重要 这几天在学习Flex布局,发现Flex真的好厉害! Flex是Flexible Box的缩写,意为“弹性布局”,用来为盒模型提供最大的灵活性。 Flex是它能够简单、完整、响应式的实现各种网页布局&#xff0c…

在Hibernate中启用实体和查询缓存

1.简介 在我执行过的与性能相关的任务中,这就是其中之一。 令人担心的是,如果每次为特定实体调用相同的查询,并且表数据在特定的时隙内不易更改,则我们可以使用Hibernate缓存查询结果。 这意味着,如果我们需要ID为1234…

php的内置函数strrpos_php strrpos 字符串查找函数内部源码实现

此函数strrpos从字符串的末尾开始查找所需要查找的字符。其他内部实现和strpos差不多是一样的。/* {{{ proto int strrpos(string haystack, string needle [, int offset]) Finds position of last occurrence of a string within another string */PHP_FUNCTION(strrpos){…