我正在使用Flask开发API,使用Marshmallow进行序列化/反序列化/验证,并使用SQLAlchemy作为ORM。
在我的更新功能中,我想限制可以更新的字段,例如,我不希望用户目前能够更改他们的电子邮件。
为了实现这一点,我设置了一个模式(UserSchema),其字段由元组(UserSchemaTypes.UPDATE_FIELDS)限制。该元组不包括电子邮件。
我遇到的问题是我的数据库中的User行需要电子邮件作为必填字段。
因此,当我使用模式创建一个User模型对象(users_schema.load(user_json))时,将向SQLAlchemy会话添加一个非法对象。
在我的更新函数中,我需要通过 db.session.expunge_all() 从会话中删除这个非法的对象,否则我会收到操作错误。
当删除db.session.expunge_all()时收到OperationalError错误:
有没有更好/更干净的方法来做这个?
在我的更新功能中,我想限制可以更新的字段,例如,我不希望用户目前能够更改他们的电子邮件。
为了实现这一点,我设置了一个模式(UserSchema),其字段由元组(UserSchemaTypes.UPDATE_FIELDS)限制。该元组不包括电子邮件。
我遇到的问题是我的数据库中的User行需要电子邮件作为必填字段。
因此,当我使用模式创建一个User模型对象(users_schema.load(user_json))时,将向SQLAlchemy会话添加一个非法对象。
#schema to validate the posted fields against
users_schema = UserSchema(only=UserSchemaTypes.UPDATE_FIELDS)
#attempt to deserialize the posted json to a User model object using the schema
user_data = users_schema.load(user_json)
if not user_data.errors:#update data passed validation
user_update_obj = user_data.data
User.update(user_id,vars(user_update_obj))
在我的更新函数中,我需要通过 db.session.expunge_all() 从会话中删除这个非法的对象,否则我会收到操作错误。
@staticmethod
def update(p_id,data):
db.session.expunge_all()#hack I want to remove
user = User.query.get(p_id)
for k, v in data.iteritems():
setattr(user, k, v)
db.session.commit()
当删除db.session.expunge_all()时收到OperationalError错误:
OperationalError: (raised as a result of Query-invoked autoflush; consider
using a session.no_autoflush block if this flush is occurring prematurely)
(_mysql_exceptions.OperationalError) (1048, "Column 'email' cannot be null") [SQL: u'INSERT INTO user (email, password, active, phone, current_login_at, last_login_at, current_login_ip, last_login_ip, login_count) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s)'] [parameters: (None, None, 1, '0444', None, None, None, None, None)]
有没有更好/更干净的方法来做这个?