django models 数据库 update_or_create 更新或者插入

本文介绍如何在Django中利用`update_or_create`方法实现数据库记录的更新或插入操作。根据date和kinds作为唯一约束,当记录存在时更新score,不存在时插入新记录。例如,date为2020-01,kinds为math,score为95时执行更新,date为2020-03,kinds为math,score为100时执行插入,而date为2020-01,kinds为math,score为92时不进行更新。
摘要由CSDN通过智能技术生成

0、需求:   插入数据库,记录存在就更新,记录不存在就插入。

id date kinds score
0 2020-01 math 92
1 2020-02 physical 88

1、首先,在models中增加插入记录的约束条件。

     假设按照date和kinds作为查询条件,更新或者插入score。

      在models中增加联合唯一(等同于数据库的联合约束)

     class Meta:
           unique_together = ("date", "kinds")

 

case1: date = 2020-01,kinds = math,score = 95,则需要更新表格

id date kinds score
0 2020-01 math 95
1 2020-02 phy
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django 中,`update_or_create` 是 `QuerySet` 对象的一个方法,用于更新现有记录或创建新记录。 该方法的使用方式如下: ```python obj, created = MyModel.objects.update_or_create(defaults={}, **kwargs) ``` 其中: - `MyModel` 是你的模型类。 - `defaults` 是一个字典,用于指定要更新或创建的字段及其对应的值。 - `kwargs` 是一个字典,用于指定用于匹配现有记录的查询条件。 该方法的返回值是一个包含两个元素的元组: - `obj` 是更新或创建的模型对象。 - `created` 是一个布尔值,指示是否创建了新记录。如果创建了新记录,则为 `True`;如果更新了现有记录,则为 `False`。 下面是对 `update_or_create` 方法的详细解释: 1. 首先,根据提供的查询条件(`kwargs`),尝试在数据库中查找匹配的记录。 2. 如果找到匹配的记录,则使用提供的 `defaults` 字典中的值来更新这条记录。 3. 如果未找到匹配的记录,则根据提供的查询条件和 `defaults` 字典中的值创建一条新记录。 这个方法适用于以下场景: - 当你想更新现有记录时,但又不确定该记录是否存在时,可以使用该方法。它会自动检查是否存在匹配的记录,并根据需要进行更新。 - 当你想创建新记录,但又要确保不会创建重复的记录时,也可以使用该方法。它会检查是否存在匹配的记录,如果不存在,则创建新记录。 注意事项: - `defaults` 字典中的键是模型字段的名称,对应的值是要更新或创建的字段值。 - `kwargs` 字典中的键是用于匹配现有记录的查询条件,可以使用模型字段名和其对应的值进行匹配。 这是关于 Django 的 `update_or_create` 方法的详细说明,希望能帮助到你!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值