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>

点个赞呗~

相关推荐
2401_882273728 分钟前
如何通过MongoDB GridFS实现文件的分块下载
jvm·数据库·python
weixin_580614008 分钟前
CSS如何实现动态背景色线性渐变_利用CSS变量控制渐变方向
jvm·数据库·python
_Evan_Yao10 分钟前
软件工程就是一场“抽象”游戏:从 abstract 关键字到架构设计的认知跃迁
java·后端·游戏·状态模式·软件工程
weixin_4087177710 分钟前
mysql如何查询所有列_mysql select星号性能分析
jvm·数据库·python
a95114164210 分钟前
mysql权限表查询性能如何优化_MySQL系统权限缓存原理
jvm·数据库·python
234710212710 分钟前
4.21 学习笔记
软件测试·笔记·python·学习
weixin_4080996711 分钟前
OCR + 自动翻译:跨境电商批量铺货方案(支持多语言自动识别)
python·ocr·机器翻译·api接口·跨境电商·ocr识别·电商自动化
江山与紫云13 分钟前
1.2 配置开发环境(VS Code / PyCharm)
ide·python·elasticsearch·pycharm
Keep Running *14 分钟前
Python基础_学习笔记
笔记·python·学习
汽车芯猿14 分钟前
嵌入式固件内存占用分析利器:Python实现S19/HEX地址空间可视化工具
python·单片机·嵌入式硬件