首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何检查唯一的bulk_create

如何检查唯一的bulk_create
EN

Stack Overflow用户
提问于 2021-10-17 02:13:12
回答 1查看 370关注 0票数 1

在Django中有一个确保对象唯一性的方法get_or_create。但是,当添加更多的记录时,1000处理需要很长时间(比如创建对象的1000个请求)。我知道bulk_create,但它不检查模型输入属性的唯一性。如何加快数据库中添加唯一对象的速度?如果可能的话,在一次请求中。

示例模型:

models.py

代码语言:javascript
运行
复制
class Person(models.Model):
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)

admin.py

代码语言:javascript
运行
复制
# Create only one element (What I want to get)
_, created = Person.objects.get_or_create(first_name='Leon', last_name='Mariano')
_, created = Person.objects.get_or_create(first_name='Leon', last_name='Mariano')

# Create 2 objects with different ID
Person.objects.bulk_create(Person(first_name='Leon', last_name='Mariano'),
                           Person(first_name='Leon', last_name='Mariano'))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-17 15:08:03

感谢Ivan的帮助。解决办法是:

models.py

代码语言:javascript
运行
复制
from django.db.models import UniqueConstraint

class Person(models.Model):
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)
    
    class Meta:
        constraints = [
            UniqueConstraint(fields=['first_name', 'last_name'], name='unique person')
        ]

admin.py

代码语言:javascript
运行
复制
Person.objects.bulk_create((
    Person(first_name='fname', last_name='lname'),
    Person(first_name='fname', last_name='lname'),
    Person(first_name='fname2', last_name='lname2'),
), ignore_conflicts= True)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69600843

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档