shu*_*NEO 7 mongoengine flask marshmallow
我有一个现有的 mongo 文档,该文档已通过 REST API 公开。API 请求将包含文档中的某些字段,如果该字段为空,则需要使用新值更新这些字段或在其中插入新值。如何对现有 mongoengine 文档的字段执行更新?我正在使用 marshmallow-mongoengine 在烧瓶上进行序列化。
我面临的问题是,如果请求负载中缺少某个字段,则在使用剩余字段作为 kwargs 调用 update 时会导致将缺少的字段设置为 None 。如何仅更新或插入有效负载中给出的字段?
约瑟夫的回答是好的。但另一个答案不会伤害呃!
这是我如何使用flask-mongoengine更新我的文档
实际代码:
Game.objects(id = _id).update(
set__kickoff = request_json.get('kickoff'),
set__gameid = request_json.get('gameid'),
set__home_team = request_json.get('home_team'),
set__away_team = request_json.get('away_team'),
set__home_win = request_json.get('home_win'),
set__draw = request_json.get('draw'),
set__away_win = request_json.get('away_win'),
set__sport = request_json.get('sport')
)
Game class :
import datetime
flask_mongoengine import BaseQuerySet, MongoEngine
db = MongoEngine()
class Game(db.Document):
kickoff = db.DateTimeField(required=True)
added_on = db.DateTimeField(default=datetime.datetime.utcnow)
gameid = db.FloatField(required=True)
home_team = db.StringField(required=True)
home_win = db.FloatField(required=True)
draw = db.FloatField(required=True)
away_win = db.FloatField(required=True)
away_team = db.StringField(required=True)
sport = db.StringField(required=True)
meta = {
'collection':'games',
'queryset_class': BaseQuerySet
}
Run Code Online (Sandbox Code Playgroud)
PS:Python中的代码记得缩进
此外,我注意到您在问题中标记了棉花糖。 这里是来自官方 git 存储库的示例
首先我们需要一个 Mongoengine 文档:
import mongoengine as me
class Task(me.EmbeddedDocument):
content = me.StringField(required=True)
priority = me.IntField(default=1)
class User(me.Document):
name = me.StringField()
password = me.StringField(required=True)
email = me.StringField()
tasks = me.ListField(me.EmbeddedDocumentField(Task))
Run Code Online (Sandbox Code Playgroud)
伟大的 !现在是棉花糖模式的时候了。为了保持干燥,我们使用 marshmallow-mongoengine 来进行映射:
import marshmallow_mongoengine as ma
class UserSchema(ma.ModelSchema):
class Meta:
model = User
Run Code Online (Sandbox Code Playgroud)
最后是时候使用我们的模式来加载/转储文档了:首先让我们创建一个文档
user_schema = UserSchema()
u, errors = user_schema.load({"name": "John Doe", "email":
"jdoe@example.com", "password": "123456","tasks": [{"content": "Find a
proper password"}]})
u.save()
Run Code Online (Sandbox Code Playgroud)
如果文档已经存在,我们可以使用 update 来更新它
u
u2, errors = user_schema.update(u, {"name": "Jacques Faite"})
>>> u2.name
"Jacques Faite"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17614 次 |
| 最近记录: |