首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python 学习手册
Python Cookbook
Python 基础教程
Python Sites
PyPI - Python Package Index
http://www.simple-is-better.com/
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
Coding
V2EX  ›  Python

Flask Admin 生成的模型视图,在创建后提交时主键为空

  •  
  •   sugarkeek · 27 天前 · 929 次点击

    模型代码:

    class Problems(db.Model):
    
        __tablename__ = 'problems'
    
        id = db.Column(db.String(45), primary_key=True)
    
        ......
    
        def __init__(self):
    
            self.id = str(uuid4())
    

    用的是 Flask Admin 默认生成的模型视图,创建后提交报错

    sqlalchemy.orm.exc.FlushError: Instance <Problems at 0x7e3b050> has a NULL identity key.  If this is an auto-generated value, check that the database table allows generation of new primary key values, and that the mapped Column object is configured to expect these generated values.  Ensure also that this flush() is not occurring at an inappropriate time, such as within a load() event.
    
    1. 这主键他默认也不显示,在构造函数里生成他也不调用。这个是 Flask Admin 需要设置的地方,还是因为我的代码有问题?

    目前我只能加上默认自动生成,不知道有没有更好的办法,或者说问题的关键在哪里?

    id = db.Column(db.String(45), primary_key=True, default=str(uuid4()))
    
    7 回复  |  直到 2019-11-15 11:02:15 +08:00
        1
    cz5424   27 天前 via iPhone
    9102 年用前后端分离吧,这个很不好用是真的
        2
    jry   27 天前 via iPhone
    同意 1 楼
        3
    mianbao1   27 天前 via iPhone
    同意 2 楼
        4
    sugarkeek   27 天前
    @cz5424 #1 我有前后端分离的...... 我前端前后端分离,后台用 flask-admin
        5
    Latin   27 天前
    重写 database 基类 CRUD 都写上,继承下就 OK 了
        6
    encro   27 天前
    id = db.Column(db.String(45), primary_key=True, default=str(uuid4()))

    这个就是对的,应该没有更好的办法。
        7
    sugarkeek   27 天前
    @Latin #5 我试试
    @encro #6 好的好的,感谢
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   970 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 27ms · UTC 21:14 · PVG 05:14 · LAX 13:14 · JFK 16:14
    ♥ Do have faith in what you're doing.