我是靠谱客的博主 犹豫萝莉,最近开发中收集的这篇文章主要介绍MongoEngine文档翻译__新手教程(三)Document实例,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

为什么80%的码农都做不了架构师?>>>   hot3.png

Document实例

创建一个新的document对象,创建一个相关document类的实例,可以在字段的构造器中赋值。你可以在任何document里面的字段设置值;

[python] 
  1. >>> page = Page(title="Test Page")  
  2. >>> page.title  
  3. 'Test Page'  
你可以使用基础对象属性的语法来赋值:
[python] 
  1. >>> page.title = "Example Page"  
  2. >>> page.title  
  3. 'Example Page'  
保存和删除Document
mongoengine在有效保存的时候会追踪document里面的变化。保存数据到数据库中,使用save() 方法。如果该document在数据库里面不存在,则会创建相应的document,如果已存在,则会应该用document中的更改:
[python] 
  1. >>> page = Page(title="Test Page")  
  2. >>> page.save()  # Performs an insert  
  3. >>> page.title = "My Page"  
  4. >>> page.save()  # Performs an atomic set on the title field.  
串联保存
如果你的document里面包含   ReferenceField 或者GenericReferenceField 对象,默认情况下使用save() 方法时会自动应用这些引用的document的变化,如果你不需要这个特性,可以把cascade 设置为 False。  

删除Document

删除document的时候,使用delete() 方法。它只在这个document存在的时候有效。

Document ID

数据库里面的没一个Document都有一个唯一的ID。这个可以通过Document的id属性来访问。通常,这个ID是由数据库在数据保存的时候自动生成的,这意味着你只能访问那些已经保存了的document的id。

[python] 
  1. >>> page = Page(title="Test Page")  
  2. >>> page.id  
  3. >>> page.save()  
  4. >>> page.id  
  5. ObjectId('123456789abcdef000000000')  

或者,你可以通过在字段构造器里面设置 primary_key=True  来指定自己的一个字段来作为主键。这种情况下,mongoengine会使用这个指定的字段作为id 。事实上,id只是你指定的主键字段的别名,你仍然可以把id 当作主键来使用:
[python]
  1. >>> class User(Document):  
  2. ...     email = StringField(primary_key=True)  
  3. ...     name = StringField()  
  4. ...  
  5. >>> bob = User(email='bob@example.com', name='Bob')  
  6. >>> bob.save()  
  7. >>> bob.id == bob.email == 'bob@example.com'  
  8. True  
你也可以使用document 的 pk 字段来访问 id ,它是id 的别名:
[python]
  1. >>> page = Page(title="Another Test Page")  
  2. >>> page.save()  
  3. >>> page.id == page.pk  

转载于:https://my.oschina.net/leaf0s/blog/129967

最后

以上就是犹豫萝莉为你收集整理的MongoEngine文档翻译__新手教程(三)Document实例的全部内容,希望文章能够帮你解决MongoEngine文档翻译__新手教程(三)Document实例所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部