Django 外键关联数据

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

原先的表是这样的
请添加图片描述
要想更改成这样:
请添加图片描述


下面是操作步骤:

有两张表是关联的

# 在 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 里定义函数

# 在 views.py 里定义一个函数

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

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

在对应的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>


点个赞呗~

相关推荐

  1. django实现

    2024-06-11 19:58:02       54 阅读
  2. Django Admin报错“冲突”排查

    2024-06-11 19:58:02       28 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-11 19:58:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-11 19:58:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-11 19:58:02       82 阅读
  4. Python语言-面向对象

    2024-06-11 19:58:02       91 阅读

热门阅读

  1. mysql(54) : dbcp多实例使用

    2024-06-11 19:58:02       22 阅读
  2. 箭头函数 this

    2024-06-11 19:58:02       28 阅读
  3. 高通Android 12应用保活时序问题踩坑

    2024-06-11 19:58:02       29 阅读
  4. R语言中的dplyr包函数总结

    2024-06-11 19:58:02       33 阅读
  5. 多人中招!企业裁员前的十大征兆!

    2024-06-11 19:58:02       25 阅读
  6. 这些Linux知识可不是靠背就会的!

    2024-06-11 19:58:02       29 阅读
  7. web前端开发转正申请:成长、挑战与未来展望

    2024-06-11 19:58:02       30 阅读
  8. 项目开发流程规范,请查收!

    2024-06-11 19:58:02       30 阅读
  9. WPF用C#代码实现设置Border颜色的渐变

    2024-06-11 19:58:02       28 阅读
  10. VSFTP虚拟用户访问-设置

    2024-06-11 19:58:02       30 阅读
  11. 用链表实现的C语言队列

    2024-06-11 19:58:02       31 阅读