位置: 编程技术 - 正文

MySQL使用外键实现级联删除与更新的方法(mysql有外键数据输入)

编辑:rootadmin

推荐整理分享MySQL使用外键实现级联删除与更新的方法(mysql有外键数据输入),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql中的外键的作用,mysql 外键作用,mysql有外键数据输入,mysql外键的使用,mysql外键语句怎么写,mysql外键用法,mysql外键语句怎么写,mysql中的外键的作用,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了MySQL使用外键实现级联删除与更新的方法。分享给大家供大家参考,具体如下:

MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引。在创建索引的时候,可以指定在删除、更新父表时,对子表进行的相应操作,包括RESTRICT、NO ACTION、SET NULL和CASCADE。其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新;CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录;SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被SET NULL。

因为只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎。我所使用的版本是Mysql5.1版本的,过程如下:

创建数据库:

创建两个表,其中第一个表的”id”是第二个表(userinfo)的外键:

注意:

1、存储引擎必须使用InnoDB引擎;

2、外键必须建立索引;

3、外键绑定关系这里使用了“ ON DELETE CASCADE ” “ON UPDATE CASCADE”,意思是如果外键对应数据被删除或者更新时,将关联数据完全删除或者相应地更新。更多信息请参考MySQL手册中关于InnoDB的文档;

好,接着我们再来插入数据测试:

我们先看一下当前数据表的状态:

MySQL使用外键实现级联删除与更新的方法(mysql有外键数据输入)

User表中的数据:

Userinfo表中的数据:

对于建立以上不表,相信对大家也没什么难度了。好的,下面我们就要试验我们的级联删除功能了。

我们将删除user表中id为2的数据记录,看看userinf表中userid为2的相关子纪录是否会自动删除:

执行删除操作成功!

看看user表中已经没有id为2的数据记录了!

再看看userinfo表中已经没有userid为2的3条数据记录了,对应数据确实自动删除了!

更新的操作也类似,因为我们在前面建表的时候已经定义外键删除、更新操作都是CASCADE,所以在这里可以直接测试数据。

将user表中原来id为1的数据记录更改为id为4,执行如下:

现在去看看两个表中是数据是否发生了变化:

比较原来的表可以发现它们的确已经更新成功了,测试完成!!!这也就实现了用外键对多个相关联的表做同时删除、更新的操作,从而保证了数据的一致性。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

MySQL触发器 Update触发Insert失败 今天工作需要,想要实现将仅对状态更新的表进行历史记录显示,于是考虑在原表中建立触发器,将更新的内容同时写入另一张表于是进行测试--建立测

MySQL中易被我们忽略的细节 MySQL作为数据库的一大主力军,到处存在于我们各种系统中,相信大家都不陌生!但是,你知道你能用不代表你知道细节,那我们就来盘点盘点其中一些

MySQL多层级结构-树搜索介绍 基本上在每个系统中都有那么几张表是自关联父子关系的结构。往往有很多人都是使用pid来做关联。在刚进入IT行业时使用CAKEPHP框架编写WEB的时候,使

标签: mysql有外键数据输入

本文链接地址:https://www.jiuchutong.com/biancheng/347905.html 转载请保留说明!

上一篇:高级MySQL数据库面试问题 附答案(mysql高级功能)

下一篇:MySQL触发器 Update触发Insert失败(mysql触发器的作用)

  • 预收款方式销售货物
  • 应征增值税不含税销售额(3%征收率)怎么填2020年
  • 融资租赁租入设备
  • 手撕定额发票不是免税怎么还报税
  • 新会计准则土地使用权摊销处理
  • 收回次月作废的发票需要做账吗
  • 小规模纳税人开普票要交税吗
  • 从业人数和资产总额是灰色
  • 上年度没有计提企业所得税
  • 其他公司归还货款会计分录
  • 期末数未分配利润为负数的会计分录怎么处理?
  • 报关单不存在
  • 淘宝企业店铺的钱会打到哪里
  • 向农户购买农产品如何入账
  • 个人定期存款利率怎么算
  • 业务订单需求表
  • 劳务公司的主营业务成本是人工工资需要个人开发票吗?
  • 怎样根据利润表做资产负债表
  • 总公司与分公司的税务关系怎么交税
  • 现金结算的股权支付等待期
  • 以前年度损益调整借贷方向
  • 钱打到对公账户
  • 如何制作macos bigsur的启动盘
  • win10点击添加账户没反应
  • 事业单位财务预算管理制度
  • 旅行社开的发票怎么入账
  • 企业收到工程款会计分录
  • 跨年退税怎么处理
  • 老大心态是什么意思
  • 公租房租金收入免企业所得税吗
  • service.exe是什么进程
  • 安置残疾人就业单位城镇土地使用税
  • 苹果手机热点打不开是灰色的
  • 发财树的养殖方法和浇水时间
  • 最小的外置dvd刻机多少寸
  • 新成立公司实收资本没到位该怎么做账
  • 金税三期个税扣缴客户端
  • 电票怎么付给别人
  • anaconda3.5.2安装教程
  • 图像的傅里叶变换和离散余弦变换实验报告
  • ntpd命令
  • 购物赠品的相关法律
  • 外购商品用于赠送增值税可以抵扣么
  • 营业执照上的注册资金可以改吗
  • 出纳记账凭证怎么写
  • 营业执照如何申请移出异常
  • 社保次月几号生效
  • sql2008附加数据库
  • 环保企业会计分录
  • 一次性扣除固定资产出售处理
  • 本月没开票还需要上报汇总吗
  • 无偿调入的固定资产其贷方应计入
  • 建筑企业结转成本附件
  • 公司模具部制作工作内容
  • 上年度记错科目怎么调整
  • 公司股东的主要几种分类
  • 有借必有贷借贷必相等的记账规则适用于
  • 老板用公司的钱算挪用公款吗
  • 保洁阿姨工资怎么扣税
  • 库存商品属于什么科目
  • sqlserver数据库优化的几种方式
  • win7电脑默认打开方式怎么设置
  • win8.1关机
  • 复制system
  • ubuntu for lot
  • Linux系统怎么调整屏幕亮度
  • centos7 阿里云 yum
  • ubuntu写脚本
  • 安装win7旗舰版变了家庭版
  • win7只能上qq不能上网页
  • jquery的用处
  • Web Safe Color Pallette
  • Unity3D游戏开发标准教程吴亚峰于复兴人民邮电出版社
  • unity3d添加组件
  • js定义数据类型
  • js回调函数应用场景
  • 个税纳税证明在哪里开
  • 贸易型企业进项发票
  • 税务局追缴社保流程及办理期限
  • 成都高新区税务局办税服务厅电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设