热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何从具有外键关系的另一个模型中检索模型列表

我是一名初级开发人员,负责构建一个将资产保存到每个员工的应用程序员

我是一名初级开发人员,负责构建一个将资产保存到每个员工的应用程序

员工可以拥有很多资产

员工只能看到自己的资产列表

class Category(models.Model):
name = models.CharField(max_length=50)
def __str__(self):
return self.name
class Asset(models.Model):
name = models.CharField(max_length=50)
# added_by = models.ForeignKey(User,on_delete=models.CASCADE,related_name='asset_added_by')
description = models.TextField()
categories = models.ForeignKey(Category,related_name='asset_categories')
image = models.ImageField(upload_to='asset_images',null=True,blank=True)
stock =models.IntegerField()
def __str__(self):
return self.name
class Department(models.Model):
name = models.CharField(max_length=50)
number_of_employees = models.IntegerField()
def __str__(self):
return self.name
class Employee(models.Model):
user = models.OneToOneField(User,)
department = models.ForeignKey(Department,)
image = models.ImageField(upload_to='employee_image',blank=True)
def __str__(self):
return self.user.username
class Registration(models.Model):
employees = models.ForeignKey(Employee,)
assets = models.ForeignKey(Asset,)
date_from = models.DateField()
date_to = models.DateField()

我对人际关系感到困惑吗?

如何获取每个员工的资产清单?


授予AssetEmployee的ForeignKey关系?然后,默认情况下,员工的资产被引用为Employee.asset_set.all()

如果资产既可以有很多员工,也可以有很多资产,那么它的ManyToMany关系就不是ForeignKey。

让一个员工看不到另一名员工的资产只是限制视图的问题。我可以想象,如果这是用户模型,那么资产列表视图将检索链接到当前登录用户的Employee。

,

听起来像现在您还没有真正掌握模型关系,或者确切地说您应该如何关联模型。您是否尝试过创建关系图的形式?即显示对象之间线条的图形(您可以在纸上完成此操作)。 (例如,您可以研究chromedriver download page)

无论如何,您要设置的内容如下:

User -<- Employee -> Department
|
^
|
Category -<- Asset

我在这里假设每个资产只能属于1名员工。如果确实是您想要的,则Nigel222所说的几乎是正确的,尽管您应将关系写在资产对象上(employee=models.ForeignKey(Employee,on_delete=models.CASCASDE))。
如果不是这种情况,则应改为添加ManyToManyField。
assets = models.ManyToManyField(Asset,on_delete=models.CASCADE)


推荐阅读
  • 深入解析Gradle中的Project核心组件
    在Gradle构建系统中,`Project` 是一个核心组件,扮演着至关重要的角色。通过使用 `./gradlew projects` 命令,可以清晰地列出当前项目结构中包含的所有子项目,这有助于开发者更好地理解和管理复杂的多模块项目。此外,`Project` 对象还提供了丰富的配置选项和生命周期管理功能,使得构建过程更加灵活高效。 ... [详细]
  • 结语 | 《探索二进制世界:软件安全与逆向分析》读书笔记:深入理解二进制代码的逆向工程方法
    结语 | 《探索二进制世界:软件安全与逆向分析》读书笔记:深入理解二进制代码的逆向工程方法 ... [详细]
  • 深入解析 Django 中用户模型的自定义方法与技巧 ... [详细]
  • 在Unity中进行3D建模的全面指南,详细介绍了市场上三种主要的3D建模工具:Blender 3D、Maya和3ds Max。每种工具的特点、优势及其在Unity开发中的应用将被深入探讨,帮助开发者选择最适合自己的建模软件。 ... [详细]
  • 在稀疏直接法视觉里程计中,通过优化特征点并采用基于光度误差最小化的灰度图像线性插值技术,提高了定位精度。该方法通过对空间点的非齐次和齐次表示进行处理,利用RGB-D传感器获取的3D坐标信息,在两帧图像之间实现精确匹配,有效减少了光度误差,提升了系统的鲁棒性和稳定性。 ... [详细]
  • RancherOS 是由 Rancher Labs 开发的一款专为 Docker 设计的轻量级 Linux 发行版,提供了一个全面的 Docker 运行环境。其引导镜像仅 20MB,非常适合在资源受限的环境中部署。本文将详细介绍如何在 ESXi 虚拟化平台上安装和配置 RancherOS,帮助用户快速搭建高效、稳定的容器化应用环境。 ... [详细]
  • Android平台生活辅助应用的设计与开发实现
    随着移动互联网技术的迅猛发展,Android操作系统已成为移动设备中的主流平台。本文探讨了基于Android平台的生活辅助应用设计与开发,旨在通过创新的功能和用户友好的界面,提升用户的日常生活质量。研究不仅涵盖了应用的核心功能实现,还深入分析了用户体验优化的方法,为同类应用的开发提供了有价值的参考。 ... [详细]
  • 在前一篇文章中,我们介绍了如何使用Requests库发送GET请求。本文将深入探讨如何通过Requests库发送POST请求,包括参数格式、请求封装等关键技巧,并通过“历史上的今天”API实例进行详细说明。 ... [详细]
  • HTML5 Web存储技术是许多开发者青睐本地应用程序的重要原因之一,因为它能够实现在客户端本地存储数据。HTML5通过引入Web Storage API,使得Web应用程序能够在浏览器中高效地存储数据,从而提升了应用的性能和用户体验。相较于传统的Cookie机制,Web Storage不仅提供了更大的存储容量,还简化了数据管理和访问的方式。本文将从基础概念、关键技术到实际应用,全面解析HTML5 Web存储技术,帮助读者深入了解其工作原理和应用场景。 ... [详细]
  • 在 PySimpleGUI 中实现异步功能的详细指南 ... [详细]
  • 如何在Spark数据排序过程中有效避免内存溢出(OOM)问题
    本文深入探讨了在使用Spark进行数据排序时如何有效预防内存溢出(OOM)问题。通过具体的代码示例,详细阐述了优化策略和技术手段,为读者在实际工作中遇到类似问题提供了宝贵的参考和指导。 ... [详细]
  • 本文探讨了如何在C#中实现USB条形码扫描仪的数据读取,并自动过滤掉键盘输入,即使不知道设备的供应商ID(VID)和产品ID(PID)。通过详细的技术指导和代码示例,展示了如何高效地处理条形码数据,确保系统能够准确识别并忽略来自键盘的干扰信号。该方法适用于多种USB条形码扫描仪,无需额外配置设备信息。 ... [详细]
  • 深入解析JWT的实现与应用
    本文深入探讨了JSON Web Token (JWT) 的实现机制及其应用场景。JWT 是一种基于 RFC 7519 标准的开放性认证协议,用于在各方之间安全地传输信息。文章详细分析了 JWT 的结构、生成和验证过程,并讨论了其在现代 Web 应用中的实际应用案例,为开发者提供了全面的理解和实践指导。 ... [详细]
  • 本文深入探讨了 HTML 中的 `margin` 属性,详细解析了其基本特性和应用场景。文章不仅介绍了 `margin` 的基本概念,还重点讨论了垂直外边距合并现象,并分析了 `margin` 在块级元素与内联元素中的不同表现。通过实例和代码示例,帮助读者全面理解 `margin` 的使用技巧和常见问题。 ... [详细]
  • Django项目中配置媒体文件路径的详细步骤与最佳实践
    在Django项目中配置媒体文件路径的详细步骤包括:首先,创建一个新的应用(如 `app02`),然后在 `settings.py` 文件中配置媒体文件的存储路径。具体来说,需要导入 `os` 模块,并使用 `os.path.join` 方法来指定媒体文件的保存目录。此外,建议在开发和生产环境中分别设置不同的媒体文件路径,以确保项目的灵活性和安全性。为了更好地管理和访问媒体文件,还可以在 `urls.py` 中添加相应的URL配置,以便在开发服务器上直接访问这些文件。 ... [详细]
author-avatar
手机用户2502924593
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有