推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
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
lbfeng
V2EX  ›  Python

flask 不能新建 table

  •  
  •   lbfeng · Jul 4, 2015 · 4808 views
    This topic created in 3997 days ago, the information mentioned may be changed or developed.

    flask新人一枚。正在读flask web development。今天尝试在flasky上添加新的功能。第一步在models中添加了几个table,接着用db upgrade生成数据库,在shell里操作models里原有的table没有问题,我添加的table却在数据库里找不到(OperationalError: (OperationalError) no such table)。有可能是什么原因呢?请大家指点。

    15 replies    2015-07-04 21:31:33 +08:00
    Septembers
        1
    Septembers  
       Jul 4, 2015
    0. 建议从0开始 看看Flask官方手册 再看Flask Web Development
    1. Flask并不包含ORM
    2. flasky使用的ORM是SQLAlchemy因此这个问题与Flask无关
      see https://github.com/miguelgrinberg/flasky/blob/master/app/__init__.py#L13
    lbfeng
        2
    lbfeng  
    OP
       Jul 4, 2015   ❤️ 1
    @Septembers 谢谢建议。问题解决了。这本书已经自学了一半了。再从0开始效率有点低了。书中的主要构架基本都能理解,但有些没搞明白。这回问题出在migration。我以为在models中添加新的table之后直接upgrade就可以,没有重新生成migration script,导致数据库中没有新的table。
    ca1n
        3
    ca1n  
       Jul 4, 2015
    flask-sqlalchemy 创建class继承Model.db之后要create_all才行嘛
    ericls
        4
    ericls  
       Jul 4, 2015 via Android
    跟flask无关吧
    loading
        5
    loading  
       Jul 4, 2015 via Android
    一直认为在初学时居然用 sqlalchemy 的 flasky就是大问题。
    不知道flasky 的人是怎么想的,也许是为了更好地提高安全性吧。(不知不觉就安全了,orm帮的忙。)
    然后初学者写别的应用时,由于没认证看 flask文档说到的安全细节…在同一个服务器下写了一个筛子程序,都是洞…
    lbfeng
        6
    lbfeng  
    OP
       Jul 4, 2015
    @ca1n 我当时用的是db upgrade
    ca1n
        7
    ca1n  
       Jul 4, 2015
    @lbfeng db就没有upgrade吧...
    sinux
        8
    sinux  
       Jul 4, 2015
    @ca1n flask-sqlalchemy的 migrate和upgrade 大概就等于django的 makemigrations 和migrate
    lbfeng
        9
    lbfeng  
    OP
       Jul 4, 2015
    @ca1n Flask applications can use the Flask- Migrate extension, a lightweight Alembic wrapper that integrates with Flask-Script to provide all operations through Flask-Script commands.
    @sinux A database migration framework keeps track of changes to a database schema, and then incremental changes can be applied to the database. migration让我比较困惑,按我理解只需要生成migration script一次,之后models有变动只需db upgrade。
    sinux
        10
    sinux  
       Jul 4, 2015
    @lbfeng models变动了,你直接upgrade,migrations文件夹内的版本,没有任何变动,所以执行的还是上一次的版本,当然就不会创建table。
    luzjoy
        11
    luzjoy  
       Jul 4, 2015
    先执行 db migrate -m 'xxx' 再执行 migrate upgrade
    ca1n
        12
    ca1n  
       Jul 4, 2015
    @sinux mirate这个库到底是做什么的 有什么优点么...感觉db的操作sqlalchemy本身就已经很简单了
    sinux
        13
    sinux  
       Jul 4, 2015
    @ca1n create_all这个api直接就创建所有的表了,不告诉你哪变了啊,migrate基于Alembic,把所有的迁移或者说数据库改动吧,都按版本记录下来了啊,你可以回溯你可以修改,像git一样,跳到某一个版本去都是可以的。
    ca1n
        14
    ca1n  
       Jul 4, 2015
    @sinux 恩..这么一说确实挺方便的 thx
    lbfeng
        15
    lbfeng  
    OP
       Jul 4, 2015
    @sinux 是的,我是在upgrade执行过程中发现没有新table的操作才反应过来。
    @luzjoy xxx 每次都要不一样吗?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2621 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 55ms · UTC 16:01 · PVG 00:01 · LAX 09:01 · JFK 12:01
    ♥ Do have faith in what you're doing.