取消票证会把指定的票证从数据库中删除,同时也会把票证和航班 等相关表中的关联关系一起删除。但在删除之前,它会先检查当前用户是否拥有这张票

ops/2025/2/27 19:24:51/

在做航班智能客服问答系统时会遇到取消票证的场景,这里涉及数据库的操作时会把指定的票证从数据库中删除,同时也会把票证和航班等相关表中的关联关系一起删除。但在删除之前,需要先检查当前用户是否拥有这张票,只有票主才有权限取消这张票。

下面用 Python 和 SQLAlchemy 举个简单的例子说明每行代码的意思:

def cancel_ticket(current_user_id, ticket_id):# 查询数据库中指定 ticket_id 的票证ticket = db.session.query(Ticket).filter_by(id=ticket_id).first()# 如果找不到票证,直接返回或抛出异常if ticket is None:raise Exception("票证不存在!")# 检查当前用户是否是票的所有者if ticket.user_id != current_user_id:raise Exception("您没有权限取消这张票!")# 删除票证与其他相关数据的关联# 例如,假设票证和航班表有外键关联,先删除关联记录related_flights = db.session.query(Flight).filter_by(ticket_id=ticket_id).all()for flight in related_flights:db.session.delete(flight)# 删除票证本身db.session.delete(ticket)# 提交事务,将所有变更保存到数据库db.session.commit()

代码逐行解释:

  1. 定义函数 cancel_ticket(current_user_id, ticket_id)
    接受当前用户的 ID 和要取消的票证 ID 作为参数。

  2. 查询票证:

    ticket = db.session.query(Ticket).filter_by(id=ticket_id).first()
    

    这行代码从数据库中查找票证表(Ticket)中与 ticket_id 匹配的记录。

  3. 检查票证是否存在:

    if ticket is None:raise Exception("票证不存在!")
    

    如果没有找到票证,就抛出异常,提醒票证不存在。

  4. 验证当前用户是否拥有这张票:

    if ticket.user_id != current_user_id:raise Exception("您没有权限取消这张票!")
    

    这行代码确保票证的所有者(ticket.user_id)和当前用户的 ID 一致,只有票主才可以取消。

  5. 删除票证与航班等关联的数据:

    related_flights = db.session.query(Flight).filter_by(ticket_id=ticket_id).all()
    for flight in related_flights:db.session.delete(flight)
    

    这里假设票证和航班表(Flight)有外键关联。首先查询所有与这张票有关联的航班记录,然后逐个删除它们。

  6. 删除票证本身:

    db.session.delete(ticket)
    

    将票证从数据库中删除。

    这里的db.session.delete是什么意思

  7. 提交事务:

    db.session.commit()
    

    将所有删除操作一次性提交到数据库,确保数据的持久性。

生活中的比喻:
想象你要取消一个活动的入场券。在你开始取消之前,系统会先检查这个入场券是不是属于你,只有你的票才可以取消。如果票上还印有其他关联的信息(比如座位号、活动安排等),这些信息也会一并清除。这样做确保了只有票主能取消自己的票,并且不会留下无效的关联记录。

为什么代码中没有删除payment的代码,是不需要特意删除payment么?

在代码中没有看到删除 Payment 的部分,可能是因为数据库设计中已经设置了级联删除(Cascade Delete)。这意味着当删除 Ticket 时,与其关联的 Payment 记录会自动被数据库删除,无需在代码中显式地删除。

打个比方:
就像在一个树状结构中,删除了树枝后,所有挂在该树枝上的叶子也会自动掉落,这个过程不需要你手动去摘每一片叶子。


举例说明:

假设在数据库中 Ticket 和 Payment 表之间有外键关联,并且设置了 ON DELETE CASCADE。例如在 SQL 中创建表时可以这样定义:

CREATE TABLE Ticket (id SERIAL PRIMARY KEY,user_id INTEGER,-- 其他字段...
);CREATE TABLE Payment (id SERIAL PRIMARY KEY,ticket_id INTEGER REFERENCES Ticket(id) ON DELETE CASCADE,amount DECIMAL,-- 其他字段...
);

在这种设置下,当删除 Ticket 时,数据库会自动删除所有关联的 Payment 记录。因此,在代码中只需要删除 Ticket:

# 查询并删除票证
ticket = db.session.query(Ticket).filter_by(id=ticket_id).first()
if ticket:db.session.delete(ticket)db.session.commit()  # 这时 Payment 记录会自动被删除

如果没有设置级联删除,则必须手动删除 Payment 记录,如下所示:

# 手动删除相关的 Payment 记录
payments = db.session.query(Payment).filter_by(ticket_id=ticket_id).all()
for payment in payments:db.session.delete(payment)# 删除票证
ticket = db.session.query(Ticket).filter_by(id=ticket_id).first()
if ticket:db.session.delete(ticket)db.session.commit()

总结来说,代码中没有专门删除 Payment,可能是因为数据库配置了级联删除,使得删除 Ticket 时,相关的 Payment 会自动删除。

数据库配置级联数删除 ON DELETE CASCADE 请点击查看更多介绍


http://www.ppmy.cn/ops/161756.html

相关文章

前端面试真题 2025最新版

文章目录 写在前文CSS怪异盒模型JS闭包闭包的形成闭包注意点 CSS选择器及优先级优先级 说说flex布局及相关属性Flex 容器相关属性:Flex 项目相关属性 响应式布局如何实现是否用过tailwindcss,有哪些好处好处缺点 说说对象的 prototype属性及原型说说 pro…

使用 Three.js 转换 GLSL 粒子效果着色器

大家好!我是 [数擎AI],一位热爱探索新技术的前端开发者,在这里分享前端和 Web3D、AI 技术的干货与实战经验。如果你对技术有热情,欢迎关注我的文章,我们一起成长、进步! 开发领域:前端开发 | AI…

JavaScript AJAX 库

注意&#xff1a;如果正在寻找可与React一起使用的AJAX库&#xff0c;请参阅React 的 AJAX 库。 这就是没有库来简化它的 AJAX 的样子。 <!DOCTYPE html> <!-- basic_ajax.html --> <html lang"en"> <head> <meta charset"UTF…

Python基于Flask的豆瓣Top250电影数据可视化分析与评分预测系统(附源码,技术说明)

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…

网络原理---HTTP/HTTPS

通过之前的网络编程&#xff0c;我们已经初步了解UDP和TCP的基本实现方法&#xff0c;接下来我们对其进一步的学习。 在网络编程中&#xff1a; 1.读和写数据通过Socket&#xff0c;通过Socket内置的InputStream和OutputStream(读写的基本单位都是字节&#xff09;。2.当在编…

【新人系列】Python 入门专栏合集

✍ 个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4dd; 专栏地址&#xff1a;https://blog.csdn.net/newin2020/category_12801353.html &#x1f4e3; 专栏定位&#xff1a;为 0 基础刚入门 Python 的小伙伴提供详细的讲解&#xff0c;也欢迎大佬们…

【Uniapp-Vue3】开发userStore用户所需的相关操作

在项目根路径下创建的stores文件夹中创建user.js文件 并将以下内容复制到user.js中 import {ref} from "vue" import { defineStore } from pinia; const uniIdCo uniCloud.importObject("uni-id-co") const db uniCloud.database(); const usersTable…

Redis底层数据结构

一. 常见数据结构的底层数据结构 1. 动态字符串SDS&#xff08;Simple Dynamic String&#xff09; 为什么要这样设计呢&#xff1f;为什么不用c语言的字符串呢? 保证二进制安全且无需遍历数组获取长度 c语言没有字符串&#xff0c;是靠字符数组实现的&#xff0c;并且以“…