什么是ondelete cascade以及使用sqlite演示ondelete cascade使用案例
什么是ondelete cascade
ON DELETE CASCADE是数据库中的一种约束,用于自动删除相关的记录。具体来说,当一个表中的记录(父表)被删除时,与其相关的其他表(子表)中的记录也会被自动删除,以维护数据库的完整性和一致性。
以下是关于ON DELETE CASCADE的详细解释:
-
用途:
主要用于维护数据库中的数据完整性和一致性。在关系型数据库中,表之间经常通过外键建立关联。当删除一个表中的记录时,与其关联的其他表中的记录可能也需要被相应地删除,以保持数据的一致性。ON DELETE CASCADE就是用来自动实现这一功能的。 -
实现方式:
在创建或修改外键约束时,可以通过指定ON DELETE CASCADE选项来启用这一功能。例如,在Oracle数据库中,可以在创建外键约束时使用ON DELETE CASCADE语句。 -
与其他选项的对比:
除了ON DELETE CASCADE外,还有其他几种处理外键约束时删除操作的方式,如ON DELETE SET NULL和ON DELETE NO ACTION。ON DELETE SET NULL会将所有相关记录的外部码字段值设置为NULL,适用于希望保留子表记录但移除关联关系的场景。而ON DELETE NO ACTION则会在试图删除父表中的记录时,如果子表中存在引用,则拒绝删除操作,适用于严格维护数据完整性、不允许孤立记录出现的场景。 -
注意事项:
使用ON DELETE CASCADE时需要谨慎,因为一旦删除操作触发,相关的子表记录将被自动删除,无法恢复。因此,在设计数据库时,需要仔细考虑是否需要使用这一功能,并确保其符合业务逻辑和数据完整性的要求。 -
示例:
假设有两个表T1和T2,T1是父表,T2是子表。T2表的某个字段与T1表的某个字段建立了外键关系。如果在T1表上设置了ON DELETE CASCADE约束,那么当删除T1表中的某条记录时,T2表中与该记录相关联的所有记录也会被自动删除。
综上所述,ON DELETE CASCADE是数据库中的一种重要约束,用于自动删除相关的记录以维护数据的完整性和一致性。在使用时需要谨慎考虑并确保其符合业务逻辑和数据完整性的要求。
使用sqlite 演示 ondelete cascade 使用案例
在这个示例中,我们将创建两个表:parents(父表)和children(子表),并在它们之间建立一个外键关系,同时指定ON DELETE CASCADE约束。
首先,我们需要创建一个SQLite数据库(如果还没有的话),然后创建这两个表。
-
创建数据库和表
-- 创建一个名为example.db的SQLite数据库(在实际操作中,你可能已经有一个数据库了) -- 这里我们假设你已经在SQLite环境中,比如通过sqlite3命令行工具或某个SQLite GUI工具 -- 创建parents表 CREATE TABLE parents (id INTEGER PRIMARY KEY,name TEXT NOT NULL ); -- 创建children表,并添加一个外键指向parents表 CREATE TABLE children (id INTEGER PRIMARY KEY,parent_id INTEGER,name TEXT NOT NULL,FOREIGN KEY (parent_id) REFERENCES parents(id) ON DELETE CASCADE ); -
插入数据
接下来,我们向这两个表中插入一些数据。
-- 向parents表插入数据 INSERT INTO parents (name) VALUES ('Parent 1'), ('Parent 2'); -- 向children表插入数据,并关联到parents表中的记录 INSERT INTO children (parent_id, name) VALUES (1, 'Child 1.1'), (1, 'Child 1.2'), (2, 'Child 2.1'); -
验证数据
现在,我们可以查询这两个表来验证数据是否正确插入。
-- 查询parents表 SELECT * FROM parents; -- 查询children表 SELECT * FROM children; -
删除父表记录并观察级联删除
最后,我们删除parents表中的一条记录,并观察children表中与之关联的记录是否被自动删除。
-- 删除parents表中id为1的记录 DELETE FROM parents WHERE id = 1;-- 再次查询children表,观察级联删除的效果 SELECT * FROM children;在删除parents表中id为1的记录后,children表中parent_id为1的记录应该已经被自动删除了,这就是ON DELETE CASCADE约束的作用。
注意事项
在SQLite中,外键支持是可选的,并且默认是关闭的。要确保外键约束被启用,你需要在连接到数据库时指定foreign_keys=ON,或者在SQLite的配置中启用它。
在实际的应用程序中,使用ON DELETE CASCADE时需要谨慎,因为它会自动删除相关数据,这可能会导致不可预见的数据丢失。在设计数据库架构时,要仔细考虑数据之间的关系和删除操作的后果。
相关文章:
什么是ondelete cascade以及使用sqlite演示ondelete cascade使用案例
什么是ondelete cascade ON DELETE CASCADE是数据库中的一种约束,用于自动删除相关的记录。具体来说,当一个表中的记录(父表)被删除时,与其相关的其他表(子表)中的记录也会被自动删除&…...
Java设计模式 —— 【结构型模式】享元模式(Flyweight Pattern) 详解
文章目录 概述结构案例实现优缺点及使用场景 概述 享元模式也叫蝇量模式:运用共享技术有效地支持大量细粒度的对象; 常用于系统底层开发,解决系统的性能问题。像数据库连接池,里面都是创建好的连接对象,在这些连接对象…...
数据的简单处理——pandas模块——选择数据
要对读取的数据进行编辑,需要先学会选择数据的操作,如果选择行数据、列数据或者同时选择行列数据。 ############################## ##作者:白雪公主的后妈 ##时间:2024年12月29日 ##主题:数据的简单处理——pandas模…...
淘宝/天猫购物车商品列表API:深度解析与应用实践
引言 在电商领域,购物车功能是提升用户体验和增加销售额的关键工具。淘宝和天猫作为中国最大的电商平台,提供了丰富的API接口,其中包括获取购物车商品列表的API,即buyer_cart_list。本文将深入解析淘宝/天猫购物车商品列表API的功…...
位置式PID-控制步进电机-位置环-stm32
基本原理 1、软件设计 本闭环控制例程是在步进电机编码器测速例程的基础上编写的,这里只讲解核心的部分代码,有些变量的设置,头文件的包含等并没有涉及到,完整的代码请参考本章配套的工程。 我们创建了4个文件:bsp_pid.c和bsp_pid.h文件用来存放PID控制器相关程序,bsp_s…...
关于Qt::BlockingQueuedConnection的死锁问题
绑定信号槽时,如果信号对象和槽对象属于不同的线程,通过Qt::BlockingQueuedConnection可以实现同步调用,即发送信号的代码等待槽函数返回才继续运行 文档的说明: Qt::QueuedConnection The slot is invoked when control returns…...
Excel for Finance 07 `FV PV` 函数
Excel 的 FV 函数用于计算一笔投资在未来的价值,基于固定的利率和定期付款。这是一个金融函数,常用来分析储蓄计划、贷款、或投资的增长。 语法: FV(rate, nper, pmt, [pv], [type])参数说明: rate(必需)&…...
驱动开发系列31 - Linux Graphics 调试 mesa 的 glDrawArrays (三)
一:概述 接着前面驱动开发系列26 - Linux Graphics 调试 mesa 的 glDrawArrays (二)-CSDN博客的文章继续分析下glDrawArrays的实现,本文介绍一下在Gallium3D HW Driver中,驱动如何将绘制命令提交给GPU执行。看下驱动层的执行逻辑:即 draw_vbo 的过程。 二:回顾下draw_vbo…...
【探花交友】day03—MongoDB基础
目录 课程介绍 1、通用设置 1.1 需求分析 1.2 查询通用设置 1.2 陌生人问题 1.3 通知设置 1.4 黑名单管理 2、MongoDB简介 1.1、MongoDB简介 1.2、MongoDB的特点 1.3 数据类型 3、MongoDB入门 2.1、数据库以及表的操作 2.2、新增数据 2.3、更新数据 2.4、删除数…...
【Vue教程】使用Vite快速搭建前端工程化项目 | Vue3 | Vite | Node.js
🙋大家好!我是毛毛张! 🌈个人首页: 神马都会亿点点的毛毛张 🚩今天毛毛张分享的是关于如何快速🏃♂️搭建一个前端工程化的项目的环境搭建以及流程🌠 文章目录 1.前端工程化环境搭建&#…...
手机租赁平台开发全攻略打造高效便捷的租赁服务系统
内容概要 手机租赁平台开发,简单说就是让用户能轻松租赁各类手机的高效系统。这一平台不仅帮助那些想要临时使用高端手机的人们节省了不少资金,还为商家开辟了新的收入渠道。随着智能手机的普及,很多人并不需要长期拥有一部手机,…...
自由学习记录(31)
Java连接MySQL 找到那个关键jar包然后导入选中,就配置好MySQL的JDBC(Java Database Connectivity)了 菜单--文件--项目结构 项目设置--模块--选择要附着的项目--选择依赖--选中模块源--选中加号添加jar包 解压之后在里面可以看到这个最关键…...
【探花交友】用户登录总结
1.发送验证码 1.发送post请求 数据封装在map 获取map的手机号码 2.调用service层将手机号码 传入过去 3.正常返回状态码200 RestController RequestMapping("/user") public class LoginController {Autowiredprivate UserService userService;/*** 获取登录验证码*…...
LabVIEW声波谐振管自动化测量系统
开发了一种基于LabVIEW的声波谐振管自动化测量系统。该系统利用LabVIEW的强大功能,实现了对声波谐振频率的精确测量,提高了实验数据的采集效率和准确性。系统主要应用于物理教学和科研中,用于研究声波在谐振管中的传播特性。 项目背景 传统的…...
elasticsearch中的倒排索引
倒排索引是搜索引擎中常用的一种数据结构,适用于全文检索,能够通过文本内容高效检索到相应的文档。 一、倒排索引的基本概念 正排索引:传统的索引方式,按照文档id顺序存储文档,通过文档id找到文档对应的词。因此当需…...
【Elasticsearch】DSL查询文档
目录 1.DSL查询文档 1.1.DSL查询分类 1.2.全文检索查询 1.2.1.使用场景 1.2.2.基本语法 1.2.3.示例 1.2.4.总结 1.3.精准查询 1.3.1.term查询 1.3.2.range查询 1.3.3.总结 1.4.地理坐标查询 1.4.1.矩形范围查询 1.4.2.附近查询 1.5.复合查询 1.5.1.相关性算分 …...
接口测试Day04-postman生成测试报告ihrm项目
测试报告-利用newman插件 安装node.js 安装 双击 .msi 文件,一路下一步安装即可。无需特殊设定。测试安装成功 npm -v 安装npm 安装newman 安装newman npm install -g newman试安装成功 newman -v安装newman插件 - 扩展版 npm install -g newman-reporter-htmlex…...
常见的排序算法过程和比较分析
比较分析 排序类别排序算法时间复杂度(最好)时间复杂度(最坏)时间复杂度(平均)辅助空间复杂度稳定性插入排序直接插入排序O(n)O(n)O(n)O(1)稳定插入排序折半插入排序O(n)O(n)O(n)O(1)稳定插入排序希尔排序…...
基于Vue+SSM+SpringCloudAlibaba书籍管理系统
功能要求 一、登录功能(http://localhost:8080/#/login) 输入账号和密码(admin/admin)进行登录: 如果密码错误,给出提示信息 如果密码正确,跳转到主页 账号或密码错误: 账号密码正确:跳转到…...
生成式 AI 增强了个人创造力,但减少了新内容的集体多样性
创造力是人类的核心。生成式人工智能 (AI)(包括强大的大型语言模型 (LLM))有望让人类通过提供新想法来更具创造力,或者通过锚定生成式 AI 想法来降低创造力。我们在一项在线实验中研究了生成式 AI 想法对短篇小说制作的因果影响,其中一些作家从 LLM 那里获得了故事创意…...
后进先出(LIFO)详解
LIFO 是 Last In, First Out 的缩写,中文译为后进先出。这是一种数据结构的工作原则,类似于一摞盘子或一叠书本: 最后放进去的元素最先出来 -想象往筒状容器里放盘子: (1)你放进的最后一个盘子(…...
地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...
MySQL 8.0 事务全面讲解
以下是一个结合两次回答的 MySQL 8.0 事务全面讲解,涵盖了事务的核心概念、操作示例、失败回滚、隔离级别、事务性 DDL 和 XA 事务等内容,并修正了查看隔离级别的命令。 MySQL 8.0 事务全面讲解 一、事务的核心概念(ACID) 事务是…...
MyBatis中关于缓存的理解
MyBatis缓存 MyBatis系统当中默认定义两级缓存:一级缓存、二级缓存 默认情况下,只有一级缓存开启(sqlSession级别的缓存)二级缓存需要手动开启配置,需要局域namespace级别的缓存 一级缓存(本地缓存&#…...
渗透实战PortSwigger靶场:lab13存储型DOM XSS详解
进来是需要留言的,先用做简单的 html 标签测试 发现面的</h1>不见了 数据包中找到了一个loadCommentsWithVulnerableEscapeHtml.js 他是把用户输入的<>进行 html 编码,输入的<>当成字符串处理回显到页面中,看来只是把用户输…...
DiscuzX3.5发帖json api
参考文章:PHP实现独立Discuz站外发帖(直连操作数据库)_discuz 发帖api-CSDN博客 简单改造了一下,适配我自己的需求 有一个站点存在多个采集站,我想通过主站拿标题,采集站拿内容 使用到的sql如下 CREATE TABLE pre_forum_post_…...
