Django一分钟:django中收集关联对象关联数据的方法

场景:我有一个模型,被其它多个模型关联,我配置了CASCADE级联删除,我想要告知用户删除该实例之后,哪些关联数据将会被一同删除。

假设我们当前有这样一组模型:

python 复制代码
class Warehouse(models.Model):
    """仓库"""
    ...
    
    
class OutboundRecord(models.Model):
    """出库单"""
    warehouse = models.ForeignKey('Warehouse', on_delete=models.CASCADE, verbose_name="仓库")
    ...
    
    
class OutboundList(models.Model):
    """出库单明细"""
    warehouse = models.ForeignKey('Warehouse', on_delete=models.CASCADE, verbose_name="仓库")
    ...


class InboundRecord(models.Model):
    """入库单"""
    warehouse = models.ForeignKey('Warehouse', on_delete=models.CASCADE, verbose_name="仓库")
    ...


class InboundList(models.Model):
    """入库明细"""
    warehouse = models.ForeignKey('Warehouse', on_delete=models.CASCADE, verbose_name="仓库")
    ...

它们的关系如下:

想要查询warehouse所有关联数据的方法很简单,具体代码如下:

python 复制代码
from django.contrib.admin.utils import NestedObjects
from xxx import Warehouse

o = NestedObjects(using='default')
o.collect(Warehouse.object.all())
print(o.nest())

假设我们事先已经插入了一些数据,上述代码会输出一个嵌套数组结构,所有的关系一目了然,嵌套数组的处理也很轻松,根据你的需要进行递归遍历即可。

python 复制代码
[
  <Warehouse: 仓库1>,
  [
    <OutboundRecord: OutboundRecord object (2)>,
    [
      <OutboundList: OutboundList object (2)>,
      <OutboundList: OutboundList object (5)>,
      <OutboundList: OutboundList object (8)>
    ],
    <OutboundRecord: OutboundRecord object (3)>,
    [
      <OutboundList: OutboundList object (3)>,
      <OutboundList: OutboundList object (6)>,
      <OutboundList: OutboundList object (9)>
    ],
    <InboundRecord: InboundRecord object (1)>,
    [
      <InboundList: InboundList object (1)>,
      <InboundList: InboundList object (4)>,
      <InboundList: InboundList object (7)>
    ]
  ],
  <Warehouse: 仓库2>,
  [
    <OutboundRecord: OutboundRecord object (1)>,
    [
      <OutboundList: OutboundList object (1)>,
      <OutboundList: OutboundList object (4)>,
      <OutboundList: OutboundList object (7)>
    ],
    <InboundRecord: InboundRecord object (2)>,
    [
      <InboundList: InboundList object (2)>,
      <InboundList: InboundList object (5)>,
      <InboundList: InboundList object (8)>
    ],
    <InboundRecord: InboundRecord object (3)>,
    [
      <InboundList: InboundList object (3)>,
      <InboundList: InboundList object (6)>,
      <InboundList: InboundList object (9)>
    ]
  ],
  <Warehouse: 仓库3>
]

NestedObjects的collect方法来自父类Collector,不过NestedObjects中多来nest()方法帮我们构建方便的层级结构。

相关推荐
晨陌y18 小时前
深入剖析:仓颉语言的性能优化核心技术
android·性能优化·仓颉
xhbh66618 小时前
【实战总结】MySQL日期加减大全:日期计算、边界处理与性能优化详解
android
00后程序员张18 小时前
如何提高 IPA 安全性 多工具组合打造可复用的 iOS 加固与反编译防护体系(IPA 安全 iOS 加固 无源码混淆 Ipa Guard 实战)
android·安全·ios·小程序·uni-app·iphone·webview
张拭心18 小时前
“不卷 AI、不碰币、下班不收消息”——Android 知名技术大牛 Jake Wharton 的求职价值观
android·前端·aigc
某空m20 小时前
【Android】DrawerLayout实现侧边导航栏
android
l1t20 小时前
在Lua用luasql-sqlite3库访问SQLite数据库
数据库·git·sqlite·lua
qqxhb21 小时前
系统架构设计师备考第61天——嵌入式系统架构模式&操作系统&数据库&中间件
数据库·中间件·系统架构·sqlite·dds·层次化(封闭/开放)·递归模式
stevenzqzq21 小时前
Android开发工作经历整理
android·简历
洞窝技术21 小时前
前端开发APP之跨平台开发(ReactNative0.74.5)
android·react native·ios
qq_717410011 天前
FAQ09934:相机prevew时候出现水印问题
android