首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >从指定数据库的集合中删除记录

从指定数据库的集合中删除记录
EN

Stack Overflow用户
提问于 2019-02-07 15:22:12
回答 1查看 125关注 0票数 0

我使用mongoDB作为我的数据库,我正在做django项目,并使用mongoengine来连接数据库。我的问题是,如果我在settings.py中的默认数据库是DB1,并且我想删除存在于all中的集合的所有记录,那么我该如何做到这一点。

settings.py

代码语言:javascript
复制
import mongoengine

mongoengine.connect(
    db= "DB1",
    host='localhost',
)

models.py

代码语言:javascript
复制
class Resources(Document):
    field1= fields.StringField(max_length=20)
    field2 = fields.StringField(max_length=70)
    field3 = fields.StringField(max_length=70)
    field4 = fields.DictField()

    meta = {'collection': 'resources', 'allow_inheritance': False, '_target_db': 'DB2'}

python外壳

代码语言:javascript
复制
from .models import Resources
import mongoengine
mongoengine.connect('DB2', alias='ces')
ob = Resources()
ob.switch_db('ces')
ob.field1 = value
ob.field2 = value
ob.field3 = value
ob.save()

现在我在DB2中有了DB1 resources,它有一些记录,我尝试过Resources.objects.all().delete() ,但它不是从DB2中删除记录,而是从默认数据库 collection 中删除记录。

EN

回答 1

Stack Overflow用户

发布于 2019-06-05 03:28:35

如果您的每个模型都绑定到1个(且只有1个)数据库,则可以使用connection aliasmeta = {'db_alias': 'your_connectio_alias'} (docs)来实现您想要的结果

有关示例,请参阅此post

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54568199

复制
相关文章

相似问题

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