flask 不能新建 table

2015-07-04 04:37:53 +08:00
 lbfeng

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

4026 次点击
所在节点    Python
15 条回复
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
lbfeng
2015-07-04 05:50:50 +08:00
@Septembers 谢谢建议。问题解决了。这本书已经自学了一半了。再从0开始效率有点低了。书中的主要构架基本都能理解,但有些没搞明白。这回问题出在migration。我以为在models中添加新的table之后直接upgrade就可以,没有重新生成migration script,导致数据库中没有新的table。
ca1n
2015-07-04 09:56:00 +08:00
flask-sqlalchemy 创建class继承Model.db之后要create_all才行嘛
ericls
2015-07-04 10:26:05 +08:00
跟flask无关吧
loading
2015-07-04 10:34:34 +08:00
一直认为在初学时居然用 sqlalchemy 的 flasky就是大问题。
不知道flasky 的人是怎么想的,也许是为了更好地提高安全性吧。(不知不觉就安全了,orm帮的忙。)
然后初学者写别的应用时,由于没认证看 flask文档说到的安全细节…在同一个服务器下写了一个筛子程序,都是洞…
lbfeng
2015-07-04 11:16:11 +08:00
@ca1n 我当时用的是db upgrade
ca1n
2015-07-04 11:22:11 +08:00
@lbfeng db就没有upgrade吧...
sinux
2015-07-04 11:55:24 +08:00
@ca1n flask-sqlalchemy的 migrate和upgrade 大概就等于django的 makemigrations 和migrate
lbfeng
2015-07-04 13:19:35 +08:00
@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
2015-07-04 13:43:38 +08:00
@lbfeng models变动了,你直接upgrade,migrations文件夹内的版本,没有任何变动,所以执行的还是上一次的版本,当然就不会创建table。
luzjoy
2015-07-04 16:28:31 +08:00
先执行 db migrate -m 'xxx' 再执行 migrate upgrade
ca1n
2015-07-04 16:29:48 +08:00
@sinux mirate这个库到底是做什么的 有什么优点么...感觉db的操作sqlalchemy本身就已经很简单了
sinux
2015-07-04 16:40:07 +08:00
@ca1n create_all这个api直接就创建所有的表了,不告诉你哪变了啊,migrate基于Alembic,把所有的迁移或者说数据库改动吧,都按版本记录下来了啊,你可以回溯你可以修改,像git一样,跳到某一个版本去都是可以的。
ca1n
2015-07-04 16:49:17 +08:00
@sinux 恩..这么一说确实挺方便的 thx
lbfeng
2015-07-04 21:31:33 +08:00
@sinux 是的,我是在upgrade执行过程中发现没有新table的操作才反应过来。
@luzjoy xxx 每次都要不一样吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/203225

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX