当前位置: 首页 > news >正文

Django:如何将多个数据表内容合在一起返回响应

一.概要

Django写后端返回响应时,通常需要返回的可能不是一个数据表的内容,还包括了这个数据表的外键所关联的其他表的一些字段,那该如何做才能把他们放在一起返回响应呢?

二.处理方法

在这里我有三个数据表

第一个是航空订单,

第二个是飞机数据

第三个是航空公司

航空订单的外键是飞机数据,飞机数据的外键又是航空公司。那我如果想把这三个的数据放在一起返回响应给怎么做呢?

flights = Flight.objects.filter(query)results = []for flight in flights:flight_data = {'id': flight.id,'departureCity': flight.departureCity,'destinationCity': flight.destinationCity,'departureDate': flight.departureDate,'plane_number': flight.plane.name, 'company_name': flight.plane.company.name}results.append(flight_data)
print(results)return Response({'data':  results,
}, status=status.HTTP_200_OK)

先创建一个空列表,然后通过flight.plane.name,flight.plane.company.name这样的方式获取到后,通过循环的方式把这些数据放在一个字典里,字典构建完成后再添加到列表当中,最后将列表进行返回。

最后打印结果如下所示。

[{'id': 1, 'departureCity': '上海', 'destinationCity': '广州', 'departureDate': datetime.date(2024, 6, 20), 'plane_number': 'MU5317', 'company_name': '东方航空'},

{'id': 2, 'departureCity': '上海', 'destinationCity': '广州', 'departureDate': datetime.date(2024, 6, 20), 'plane_number': 'AQ1006', 'company_name': '九元航空'}]

三.总结

创建一个空列表,通过循环的方式把其他数据表的字段和原有数据表的字段放在一个字典里,字段构建完成后添加到列表中,最后把这个列表进行返回
 

http://www.lryc.cn/news/376968.html

相关文章:

  • 棱镜七彩荣获CNNVD两项大奖,专业能力与贡献再获认可!
  • uni-app中使用富文本rich-text个人经验
  • Matlab|基于V图的配电网电动汽车充电站选址定容-可视化
  • 从零开始! Jupyter Notebook的安装教程
  • web前端信息卡:深入探索与实用指南
  • 之所以选择天津工业大学,因为它是双一流、报考难度适宜,性价比高!天津工业大学计算机考研考情分析!
  • WPF三方UI库全局应用MessageBox样式(.NET6版本)
  • ABAP-03基础数据类型
  • Zabbix监控神通数据库教程
  • 5.音视频基础 FLV
  • Ubuntu server 24 (Linux) 安装客户端(windows/linux) Zabbix 7.0 LTS Zabbix agent2
  • 在 Ubuntu 上取消登录密码和锁屏功能的简易指南
  • PAT B1046. 划拳
  • 奥特曼谈AI的机遇、挑战与人类自我反思:中国将拥有独特的大语言模型
  • Java版-剑指offer数据结构与算法 视频教程 下载
  • mac禁用电池睡眠-mac盒盖连接显示器
  • 最好用的智能猫砂盆存在吗?自用分享智能猫砂盆测评!
  • LeetCode 每日一题 2748. 美丽下标对的数目
  • 全民拼购:引领商业新潮流,共创共赢新篇章
  • HarmonyOS角落里的知识:一杯冰美式的时间 -- 之打字机
  • C++ 03 之 命名空间
  • 20个国家科学数据中心(下)
  • 本地部署 Stable Diffusion3
  • 避免Tomcat调试信息泄露的最佳实践
  • Linux C++
  • Apache Doris 基础 -- 部分数据类型及操作
  • 大话C语言:第25篇 动态库
  • 数据分析:RT-qPCR分析及R语言绘图
  • 无线模块通过TCP/IP协议实现与PC端的数据传输解析
  • 嵌入式实验---实验一 通用GPIO实验