php mysql级联操作_mysql级联操作(范例)_mysql-程序员宅基地

技术标签: php mysql级联操作  

mysql级联操作(实例)

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

17f43368de8ac164e4909e936f0fff24.png

create database yynews;

use yynews;

#新闻类别表

create table categories(

catId int AUTO_INCREMENT primary key,

catName varchar(40) not null unique

)charset utf8;

#新闻表:

create table news(

newsId int AUTO_INCREMENT primary key,

title varchar(100) not null unique,

content text not null,

createTime timestamp not null,

catId int

)charset utf8;

#添加外键的引用

alter table news add constraint foreign key(catid) references categories(catid);

#评论表:

create table comments(

commId int AUTO_INCREMENT primary key,

content text not null,

createTime timestamp not null,

newsId int not null,

userIP char(15) not null

)charset utf8;

#添加外键的引用

alter table comments add constraint foreign key(newsid) references news(newsid);

#插入测试数据

insert into categories(catname) values("娱乐新闻");

insert into categories(catname) values("国际新闻");

insert into news(title,content,createTime,catId) values('test1','test1',now(),1);

insert into news(title,content,createTime,catId) values('test2','test2',now(),2);

insert into news(title,content,createTime,catId) values('test3','test3',now(),1);

insert into comments(content,createTime,newsId,userIP) values('you',now(),1,'127.0.0.1');

insert into comments(content,createTime,newsId,userIP) values('you',now(),2,'127.0.0.1');

insert into comments(content,createTime,newsId,userIP) values('you',now(),3,'127.0.0.1');

insert into comments(content,createTime,newsId,userIP) values('you',now(),1,'127.0.0.1');

如下:

mysql> select * from categories;

+-------+--------------+

| catId | catName      |

+-------+--------------+

|     2 | 国际新闻     |

|     1 | 娱乐新闻     |

+-------+--------------+

2 rows in set (0.00 sec)

mysql> select * from news;

+--------+-------+---------+---------------------+-------+

| newsId | title | content | createTime          | catId |

+--------+-------+---------+---------------------+-------+

|      1 | test1 | test1   | 2015-05-19 15:22:53 |     1 |

|      2 | test2 | test2   | 2015-05-19 15:22:53 |     2 |

|      3 | test3 | test3   | 2015-05-19 15:22:53 |     1 |

+--------+-------+---------+---------------------+-------+

3 rows in set (0.00 sec)

mysql> select * from comments;

+--------+---------+---------------------+--------+-----------+

| commId | content | createTime          | newsId | userIP    |

+--------+---------+---------------------+--------+-----------+

|      1 | you     | 2015-05-19 15:22:53 |      1 | 127.0.0.1 |

|      2 | you     | 2015-05-19 15:22:53 |      2 | 127.0.0.1 |

|      3 | you     | 2015-05-19 15:22:53 |      3 | 127.0.0.1 |

|      4 | you     | 2015-05-19 15:22:54 |      1 | 127.0.0.1 |

+--------+---------+---------------------+--------+-----------+

4 rows in set (0.00 sec)

在还没有添加任何的级联操作的时,删除有关联的数据会报错。

mysql> delete from categories where catid=1;

ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`yynews`.

`comments`, CONSTRAINT `comments_ibfk_1` FOREIGN KEY (`newsId`) REFERENCES `news` (`newsId`))

数据库报错告诉你有个外键阻止了你的操作。所以我们可以添加级联操作。也可以再创建数据库的时候就指定级联操作

如下:

#级联操作

alter table news add constraint foreign key(catid) references categories(catid) on delete cascade

on update cascade;

alter table comments add constraint foreign key(newsid) references news(newsid) on delete cascade

on update cascade;

#上面这句的这两个语句就是在添加外键的时候为该表和表之间添加级联操作,即,数据表在删除或更新数据表时,相

关连的表也会同时更新或删除。

例如:

mysql> delete from categories where catid=1;

Query OK, 1 row affected (0.03 sec)

我们删除了类别catid为1的数据即:娱乐新闻,那么有关娱乐新闻的news中的数据double将会被删除,新闻被删除的同时,新闻下的评论也会被同时删除。

如下所示:

mysql> select * from news;

+--------+-------+---------+---------------------+-------+

| newsId | title | content | createTime          | catId |

+--------+-------+---------+---------------------+-------+

|      2 | test2 | test2   | 2015-05-19 15:17:03 |     2 |

+--------+-------+---------+---------------------+-------+

1 row in set (0.00 sec)

mysql> select * from comments;

+--------+---------+---------------------+--------+-----------+

| commId | content | createTime          | newsId | userIP    |

+--------+---------+---------------------+--------+-----------+

|      2 | you     | 2015-05-19 15:17:03 |      2 | 127.0.0.1 |

+--------+---------+---------------------+--------+-----------+

1 row in set (0.00 sec)

欢迎大家阅读《mysql级联操作(范例)_mysql》,跪求各位点评,by 搞代码

e7ce419cf2d6ad34d01da2ceb8829eed.png

微信 赏一包辣条吧~

023a57327877fb4402bcc76911ec18ea.png

支付宝 赏一听可乐吧~

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_35552177/article/details/113343218

智能推荐

Python+Selenium UI自动化之元素定位方式_python ui自动化判断元素是否存在-程序员宅基地

文章浏览阅读1.3k次。1. 网页元素介绍?元素: 由标签头+标签尾+标签头和标签尾包括的文本内容元素的信息就是指元素的标签名以及元素的属性元素的层级结构就是指元素之间相互嵌套的层级结构元素定位最终就是通过元素的信息或者元素的层级结构来进行元素定位。2. 浏览器开发者工具介绍浏览器开发者工作主要用来查看元素的信息, 同时也可以查看接口的相关信息。 浏览器开发者工作不需要安装,浏览器自带. 浏览器开发者工具的启动: 直接按F12 不区分浏览器 通过右键的方式来启动浏览器开发者工具 (谷歌浏览器右.._python ui自动化判断元素是否存在

中国程序员独立开发9年、最受欢迎的开源Redis客户端——被Redis公司收购-程序员宅基地

文章浏览阅读29次。ioredis 作者@Luin宣布该项目已被 Redis 公司收购。目前 ioredis 在 GitHub 的开源地址已迁移至 Redis 公司旗下:ioredis 是一个用于 Node.js 的 Redis 客户端,健壮、性能好、功能强大且全面。两年前,ioredis超过redis 成为了 Node.js 最流行的 Redis 客户端。当时 ioredis 作者还感叹 redis 历经诸...

javase之序列化与反序列化_ser 序列化 反射-程序员宅基地

文章浏览阅读406次。3.如果一个可序列化对象包含了某个不可序列化对象的引用,那么整个序列化是会失败的,并且会抛出一个NotSerializableException,我们可以将这个引用标记为transient,表示为短暂的,此时该变量就无法被序列化,然后对象依旧可以被序列化。一个类如果想被序列化,则必须实现java.io.Serializable接口,这个接口没有定义任何方法,是一个标志性接口,当一个类实现了该接口,就表示这个类的对象是可以被序列化的。2.如果一个对象的成员变量是一个对象,那么这个对象的数据成员也会被保存。.._ser 序列化 反射

Zuul_zuul: prefix: /api-程序员宅基地

文章浏览阅读139次。zuul 路由1. zuul:1.1 zuul是什么?Zuul包含了对请求的路由和过滤两个最主要的功能:其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。注意:Zuul服务最终还是会注册进Eureka1.2 路由:_zuul: prefix: /api

推荐五款你从未见过的嵌入式电子电路仿真APP-程序员宅基地

文章浏览阅读2.1w次,点赞30次,收藏204次。摘要:在这个人人一部甚至多部智能手机的年代,各种APP充斥在各种应用市场作为一名电子爱好者或者电子工程师,你在为如何选择APP而头痛吗?哪些你正在使用的APP使你在工作、生活、学习中如虎添翼呢?现在,小师弟特意整理了一些电子爱好者和电子工程师能用到的手机APP和你没见过的电脑仿真软件。ElectroDroid电路专家ElectroDroid是一款电路电子器件的学习软件,比较专业化,它能够为你提供各种电路方面的信息查询和计算服务,是电子相关行业人士的必备工具之一。它包括:电阻色码计算器贴片电阻代码_电路仿真app

卷积神经网络的几种模型_卷积神经网络模型-程序员宅基地

文章浏览阅读7.9k次,点赞9次,收藏53次。关于卷积神经网络的模型,我们这里只谈论关于图像分类的卷积神经网络的四种模型。在这里我们就不对卷积神经网络的结构进行阐述,不了解的同学可以参考我之前的博客LeNet-5首先我们先阐述的是1989年提出来的的LeNet-5结构。它其实就是最原始的结构,卷积层后衔接池化层,再接卷积层和其后的池化层,最后一个全连接层。(c1=convolution layer1,s1=subsampling layer1[降采样层,就是池化层])这个模型是实现识别手写数字的功能为目的而提出..._卷积神经网络模型

随便推点

科普帖:什么是IaaS?与SaaS、PaaS有何不同_google drive iaas-程序员宅基地

文章浏览阅读853次,点赞24次,收藏18次。到底什么是IaaS?它与PaaS和SaaS等其他云服务有何不同?​本文将介绍它们之间的区别。随着91%的公司至少部分迁移到云,我们都应该对它们有基本了解。下面让我们探讨一下IaaS是什么,与其他云服务的区别,及一些实际使用中的示例。_google drive iaas

滚动栏范围位置函数(SetScrollRange、SetScrollPos、GetScrollRange、GetScrollPos)-程序员宅基地

文章浏览阅读194次。滚动栏的范围是一对整数,默认情况下,滚动栏的范围是0~100。SetScrollRange(hwnd,iBar,iMin,iMax,bRedraw)这里的iBar參数要么是SB_VERT,要么是SB_HORZ,iMin和iMax分别相应滚动栏范围的最小值和最大值,须要Windows依据新的范围来重绘滚动栏时将bRedraw设为TRUE.SetScrollPos(hwnd..._setscrollerbarpos

【Java基础】之AWT,一篇文章搞懂awt(包含绘图)-程序员宅基地

文章浏览阅读1.3w次,点赞45次,收藏177次。入门awt不错的文章,带你快速上手awt_awt

C++ Primer问题总结(7)_executionpolicy&&-程序员宅基地

文章浏览阅读170次。10.3int main(){ vector<string>v{ "Hello","World" }; auto sum = accumulate(v.begin(), v.end(), string{ "Tim Wu" }); cout << sum << endl;}int main(){ int v1 = 42; auto f ..._executionpolicy&&

《近匠》专访机智云 CTO 刘琰——从 0 到 1 开启智能化硬件开发-程序员宅基地

文章浏览阅读1.1k次。在物联网浪潮之下,智能硬件的火爆程度不断升温。未来十年,全球接入互联网的硬件设备将达到1万亿台。如今的智能硬件产品正成为下一个“台风口”,同时这对于终端市场也是一个机遇。然而从创新走向产品,作为开发者应该如何步步为营?面对传统硬件与智能硬件之间思维理念及技术差异的“鸿沟”,开发者如何提升自己的技能,更加高效地开发?由此,我们带着探索道路上的种种疑问,采访了机智云 CTO ..._机智云科技有限公司刘焱

动态规划 | 完全背包问题 | 组合数、排列数 | leecode刷题笔记_完全背包问题 输出有几种排列-程序员宅基地

文章浏览阅读857次。跟随carl代码随想录刷题语言:python。_完全背包问题 输出有几种排列