flask新人一枚。正在读flask web development。今天尝试在flasky上添加新的功能。第一步在models中添加了几个table,接着用db upgrade生成数据库,在shell里操作models里原有的table没有问题,我添加的table却在数据库里找不到(OperationalError: (OperationalError) no such table)。有可能是什么原因呢?请大家指点。
1
Septembers 2015-07-04 04:52:19 +08:00
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 |
2
lbfeng OP @Septembers 谢谢建议。问题解决了。这本书已经自学了一半了。再从0开始效率有点低了。书中的主要构架基本都能理解,但有些没搞明白。这回问题出在migration。我以为在models中添加新的table之后直接upgrade就可以,没有重新生成migration script,导致数据库中没有新的table。
|
3
ca1n 2015-07-04 09:56:00 +08:00
flask-sqlalchemy 创建class继承Model.db之后要create_all才行嘛
|
4
ericls 2015-07-04 10:26:05 +08:00 via Android
跟flask无关吧
|
5
loading 2015-07-04 10:34:34 +08:00 via Android
一直认为在初学时居然用 sqlalchemy 的 flasky就是大问题。
不知道flasky 的人是怎么想的,也许是为了更好地提高安全性吧。(不知不觉就安全了,orm帮的忙。) 然后初学者写别的应用时,由于没认证看 flask文档说到的安全细节…在同一个服务器下写了一个筛子程序,都是洞… |
8
sinux 2015-07-04 11:55:24 +08:00
@ca1n flask-sqlalchemy的 migrate和upgrade 大概就等于django的 makemigrations 和migrate
|
9
lbfeng OP @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。 |
10
sinux 2015-07-04 13:43:38 +08:00
@lbfeng models变动了,你直接upgrade,migrations文件夹内的版本,没有任何变动,所以执行的还是上一次的版本,当然就不会创建table。
|
11
luzjoy 2015-07-04 16:28:31 +08:00
先执行 db migrate -m 'xxx' 再执行 migrate upgrade
|