python - Flask 和 Postgresql - sqlalchemy.exc.DataError: (psycopg2.errors.InvalidTextRepresentation) 枚举的无效输入值
问题描述
这是模型
from sqlalchemy.dialects import postgresql
class MyModel(db.Model):
__tablename__ = 'mytables'
id = db.Column(db.Integer, primary_key=True)
datetime = db.Column(db.DateTime, nullable=False)
option = db.Column(postgresql.ENUM('YES', 'NO', 'MAYBE', name='_option', create_type=False), nullable=False)
data = db.Column(db.String(20))
这是我用来存储数据的类
class myList(Resource):
parser = reqparse.RequestParser()
def post(self):
data = myList.parser.parse_args()
my_json = request.get_json()
my_data = my_schema.load(my_json)
my_data.save()
return my_schema.dump(my_data), 201
这是我的架构
from ma import ma
from models.mymodel import MyModel
class MySchema(ma.SQLAlchemyAutoSchema):
class Meta:
model = MyModel
load_instance = True
include_fk = True
这是完整的错误消息,假设我输入 YES
sqlalchemy.exc.DataError: (psycopg2.errors.InvalidTextRepresentation) invalid input value for enum status_option: ""YES""
解决方案
最后我找到了解决方案
所以在我提出问题的模型表下面,我有这个方法
def __init__(self, datetime, option, data):
self.datetime = datetime
self.option = json.dumps(option)
self.data = data
然后我把它改成这个和它的工作
def __init__(self, datetime, option, data):
self.datetime = datetime
self.option = option
self.data = data
推荐阅读
- r - 按r中的特定日期顺序分组
- c# - 打字稿为什么我的 Get 请求以骆驼案的形式出现?
- bixby - Bixby Capsule 中 Javascript API 中的“类型”模块的目的是什么?
- kdb - Q/Kdb:组合两列以创建一个新列作为列表
- javascript - 如何在 Flow 中声明一个更改参数而没有 ESLint 错误的函数
- java - 将使用记录器的错误正确转换为常规字符串
- php - 405 方法不允许 - PUT (PHP)
- java - @Refreshscope 与 DriverManagerDataSource
- python-3.x - 如何通过其中一列中的每个值将一列随机数添加到数据框中?
- node.js - 如何测试我的猫鼬预保存钩子中的 if 语句