Django 外键关联数据

在设计数据库的时候,是得需要通过外键的形式将各个表进行连接。

原先的表是这样的

要想更改成这样:


下面是操作步骤:

有两张表是关联的

python 复制代码
# 在 models.py 里创建

class Department(models.Model):
    """
    部门表
    """
    title = models.CharField(verbose_name="标题", max_length=16)

class AssetSet(models.Model):
    """
    资产表
    """
    name = models.CharField(verbose_name="名称", max_length=32)
    price = models.IntegerField(verbose_name="价格")

    # 只适用于固定的选择
    category = models.SmallIntegerField(verbose_name="资产类型", choices=((1, '文具类'), (2, '3C类'), (3, '房产类')))

    # 外键 depart_id
    depart = models.ForeignKey(verbose_name="所属部门", to="Department", to_field="id", on_delete=models.CASCADE)

views.py 里定义函数

python 复制代码
# 在 views.py 里定义一个函数

def asset_list(request):
    queryset = models.AssetSet.objects.all().order_by("-id")

    return render(request, 'asset_list.html', { "queryset": queryset })

在对应的html文件里实现前端页面

html 复制代码
<table border="1px">
    <thead>
        <tr>
            <th>ID</th>
            <th>标题</th>
            <th>价格</th>
            <th>分类</th>
            <th>所属部门</th>
        </tr>
    </thead>
    <tbody>
        {% for obj in queryset %}
        <tr>
            <td>{{ obj.id }}</td>
            <td>{{ obj.name }}</td>
            <td>{{ obj.price }}</td>
            <td>{{ obj.get_category_display }}</td>
            <td>{{ obj.depart.title }}</td>   <!-- 直接调用对应的title就可以了 -->
        </tr>
        {% endfor %}
    </tbody>
</table>

点个赞呗~

相关推荐
数据狐(DataFox)33 分钟前
CTE公用表表达式的可读性与性能优化
经验分享·python·sql
蹦蹦跳跳真可爱58938 分钟前
Python----MCP(MCP 简介、uv工具、创建MCP流程、MCP客户端接入Qwen、MCP客户端接入vLLM)
开发语言·人工智能·python·语言模型
No0d1es40 分钟前
第13届蓝桥杯Python青少组中/高级组选拔赛(STEMA)2022年1月22日真题
python·青少年编程·蓝桥杯·选拔赛
MediaTea1 小时前
Python 库手册:getopt Unix 风格参数解析模块
服务器·开发语言·python·unix
王尼莫啊1 小时前
【立体标定】圆形标定板标定python实现
开发语言·python·opencv
cosX+sinY2 小时前
10 卷积神经网络
python·深度学习·cnn
Livingbody2 小时前
【心理咨询师数字孪生对话数据集】标准化为 ShareGPT OpenAI 格式
后端
非极限码农2 小时前
基于Deepseek的语言润色助手API实现与部署指南
python·微服务·自然语言处理
I love studying!!!2 小时前
python基础:用户输入和 while 循环
python
AndrewHZ3 小时前
【图像处理基石】如何对遥感图像进行实例分割?
图像处理·人工智能·python·大模型·实例分割·detectron2·遥感图像分割