首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Flask和Postgresql - sqlalchemy.exc.DataError:(psycopg2.errors.InvalidTextRepresentation)枚举的输入值无效

Flask和Postgresql - sqlalchemy.exc.DataError:(psycopg2.errors.InvalidTextRepresentation)枚举的输入值无效
EN

Stack Overflow用户
提问于 2021-11-04 02:57:45
回答 1查看 135关注 0票数 0

这就是模型

代码语言:javascript
运行
复制
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))

这是我用来存储数据的类

代码语言:javascript
运行
复制
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

这是我的方案

代码语言:javascript
运行
复制
from ma import ma
from models.mymodel import MyModel

class MySchema(ma.SQLAlchemyAutoSchema):
    class Meta:
        model = MyModel
        load_instance = True
        include_fk = True

这是完整的错误消息,假设我给出了YES输入

代码语言:javascript
运行
复制
sqlalchemy.exc.DataError: (psycopg2.errors.InvalidTextRepresentation) invalid input value for enum status_option: ""YES""
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-04 08:08:46

最后我找到了解决方案

所以在我提出问题的模型表下面,我有这个方法

代码语言:javascript
运行
复制
def __init__(self, datetime, option, data):
    self.datetime = datetime
    self.option = json.dumps(option)
    self.data = data

然后我把它改成这样,它就能工作了

代码语言:javascript
运行
复制
def __init__(self, datetime, option, data):
    self.datetime = datetime
    self.option = option
    self.data = data
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69834062

复制
相关文章

相似问题

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